SpringCloud服务接口调用OpenFeign及使用详解

2023-05-14 05:05:52 调用 接口 详解

OpenFeign简介

Feign是一个声明式的WEB服务客户端,让编写Web服务客户端变得非常容易,只需创建一个接口并在接口上添加注解即可。

学习Ribbon时,服务间调用使用的是RestTemplate+Ribbon实现,而Feign在此基础上继续进行了封装,使服务间调用变得更加方便。

而OpenFeign可以理解为Feign的升级版。

OpenFeign使用

OpenFeign应用在消费端,服务端不需要做任何改变

创建一个新的消费端cloud-consumer-feign-order80,首先引入相关依赖,引入OpenFeign以后,可以看到OpenFeign内置了Ribbon,所以他底层实现负载均衡还是依赖于Ribbon


<dependencies>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>

    <dependency>
        <groupId>com.yellowstar.SpringCloud</groupId>
        <artifactId>cloud-api-commons</artifactId>
        <version>1.0-SNAPSHOT</version>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <scope>runtime</scope>
        <optional>true</optional>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <optional>true</optional>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

编写配置文件

server.port=80

eureka.client.reGISter-with-eureka=false
eureka.client.service-url.defaultZone=Http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka  

在启动类上添加如下注解

@EnableFeignClients

对于OpenFeign来说,服务间的调用需要在消费端创建一个接口,这个接口类似于服务端

@Component
@FeignClient(value = "CLOUD-PAYMENT-SERVICE")
public interface PaymentFeignService {
    @GetMapping("/payment/get/{id}")
    CommonResult<Payment> getPayment(@PathVariable("id") int id);
}

OpenFeign超时控制

默认情况下,OpenFeign调用方法,会给该方法一秒钟的执行时间,如果一秒钟之后没有执行完方法,则直接报错。而OpenFeign底层调用的Ribbon,也就是说我们需要设置Ribbon服务间调用的等待时间

#指的是建立连接所用的时间,适用于网络状况正常的情况下,两端连接所用的时间
ribbon.ReadTimeout=5000l
#指的是建立连接后从服务器读取到可用资源所用的时间
ribbon.ConnectTimeout=5000

如果不设置,会报一下错误

OpenFeign日志

OpenFeign在调用http请求时,可以将请求的日志完整的打印出来,有以下几种日志级别,默认是无日志。

  • NONE:默认的,不显示任何日志;
  • BASIC:仅记录请求方法、URL、响应状态码及执行时间;
  • HEADERS:除了 BASIC 中定义的信息之外,还有请求和响应的头信息;
  • FULL:除了 HEADERS 中定义的信息之外,还有请求和响应的正文及元数据。

首先需要对Feign的日志级别进行配置

@Configuration
public class FeignConfig {
    @Bean
    Logger.Level feignLoggerLevel() {
        return Logger.Level.FULL;
    }
}

添加配置文件

# feign日志以什么级别监控哪个接口
logging.level.com.yellowstar.sprinGCloud.service.PaymentFeignService=debug

接下来就可以观察http请求的完整信息了

到此这篇关于SpringCloud服务接口调用——OpenFeign的文章就介绍到这了,更多相关SpringCloud OpenFeign服务调用内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

相关文章