评论

收藏

[Java] SpringCloud Feign 服务调用的实现

编程语言 编程语言 发布于:2021-10-05 22:08 | 阅读数:425 | 评论:0

Feign是一个声明性web服务客户端。本文记录多个服务之间使用Feign调用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
前言
前面我们已经实现了服务的注册与发现(请戳:springcloud系列——eureka 服务注册与发现),并且在注册中心注册了一个服务myspringboot,本文记录多个服务之间使用feign调用。
feign是一个声明性web服务客户端。它使编写web服务客户机变得更容易,本质上就是一个http,内部进行了封装而已。
github地址:https://github.com/openfeign/feign
官方文档:https://cloud.spring.io/spring-cloud-static/spring-cloud-openfeign/2.1.0.rc2/single/spring-cloud-openfeign.html
服务提供者
提供者除了要在注册中心注册之外,不需要引入其他东西,注意一下几点即可:
1、如果使用对象接参,必须使用@requestbody,否则接不到数据
2、接参只能出现一个复杂对象,例:public result<list<uservo>> list(@requestbody uservo entityvo) { ... }
3、提供者如果又要向其他消费者提供服务,又要向浏览器提供服务,建议保持原先的controller,新建一个专门给消费者的controller
测试接口
@restcontroller
@requestmapping("/user/")
public class usercontroller {
 
  @autowired
  private userservice userservice;
  @requestmapping("list")
  public result<list<uservo>> list(@requestbody uservo entityvo) {
  return userservice.list(entityvo);
  }
 
  @requestmapping("get/{id}")
  public result<uservo> get(@pathvariable("id") integer id) {
  return userservice.get(id);
  }
}
服务消费者
消费者maven引入jar
<!-- feign -->
  <dependency>
  <groupid>org.springframework.cloud</groupid>
  <artifactid>spring-cloud-starter-openfeign</artifactid>
  </dependency>
配置文件
对日期的解析,消费者要跟提供者一致,不然会报json解析错误
#超时时间
feign.httpclient.connection-timeout=30000
 
#mvc接收参数时对日期进行格式化
spring.mvc.date-format=yyyy-mm-dd hh:mm:ss
#jackson对响应回去的日期参数进行格式化
spring.jackson.date-format=yyyy-mm-dd hh:mm:ss
spring.jackson.time-zone=gmt+8
服务调用
1、springdatejpa 应用名称,是服务提供者在eureka注册的名字,feign会从注册中心获取实例
2、如果不想启动eureka服务,直连本地开发:@feignclient(name = "springdatejpa", path = "/user/",url = "http://localhost:10086")
3、如果使用@requestmapping,最好指定调用方式
4、消费者的返回值必须与提供者的返回值一致,参数对象也要一致
更多@feignclient注解参数配置,请参阅官方文档
@feignclient(name = "springdatejpa", path = "/user/")
public interface myspringbootfeign {
 
  @requestmapping(value = "get/{id}")
  result<uservo> get(@pathvariable("id") integer id);
 
  @requestmapping(value = "list", method = requestmethod.get)
  result<list<uservo>> list(@requestbody uservo entityvo);
}
/**
   * feign调用
   */
  @getmapping("feign/get/{id}")
  result<uservo> get(@pathvariable("id") integer id){
  return myspringbootfeign.get(id);
  }
 
 
  /**
   * feign调用
   */
  @getmapping("feign/list")
  result<list<uservo>> list(uservo uservo){
  return myspringbootfeign.list(uservo);
  }
启动类
启动类加入注解:@enablefeignclients
@enableeurekaclient
@enablefeignclients
@springbootapplication
public class myspringbootapplication{
 
  public static void main(string[] args) {
  springapplication.run(myspringbootapplication.class, args);
  }
 
}
效果
成功注册两个服务
DSC0000.jpg

成功调用
DSC0001.jpg

DSC0002.jpg

报错记录
1、启动时报了个sql错误
DSC0003.jpg

解决:配置文件连接数据时指定servertimezone=gmt%2b8
DSC0004.jpg

2、当我将之前搭好的一个springboot-springdata-jpa整合项目在eureka注册时出现了一个报错
DSC0005.jpg

然后在网上查了下说是因为springboot版本问题,之前这个项目用的是2.0.1.release,现在要在eureka注册,pom引入了就出现了上面的报错
<!-- eureka-client -->
  <dependency>
    <groupid>org.springframework.cloud</groupid>
    <artifactid>spring-cloud-starter-netflix-eureka-client</artifactid>
  </dependency>
 
  <!-- actuator -->
  <dependency>
    <groupid>org.springframework.boot</groupid>
    <artifactid>spring-boot-starter-actuator</artifactid>
  </dependency>
<dependencymanagement>
  <dependencies>
    <dependency>
    <groupid>org.springframework.cloud</groupid>
    <artifactid>spring-cloud-dependencies</artifactid>
    <version>greenwich.rc1</version>
    <type>pom</type>
    <scope>import</scope>
    </dependency>
  </dependencies>
  </dependencymanagement>
  <repositories>
  <repository>
    <id>spring-milestones</id>
    <name>spring milestones</name>
    <url>https://repo.spring.io/milestone</url>
  </repository>
  </repositories>
解决:升级了springboot版本,2.1.0,项目正常启动
<parent>
  <groupid>org.springframework.boot</groupid>
  <artifactid>spring-boot-starter-parent</artifactid>
  <version>2.1.0.release</version>
  <!--<version>2.0.1.release</version>-->
  <relativepath/> <!-- lookup parent from repository -->
  </parent>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持CodeAE代码之家
原文链接:https://www.cnblogs.com/huanzi-qch/p/10135946.html

关注下面的标签,发现更多相似文章