1、是什么:Feign是一个声明式的Web服务客户端,让编写Web服务客户端变得非常容易,只需创建一个接口并在接口上添加注解即可。
微服务调用接口+@FeignClient
2、使用步骤
1⃣️新建cloud-consumer-feign-order80
2⃣️改POM:在eureka的基础上增加openfeign的依赖即可。
<!--openfeign-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<!--eureka client-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
3⃣️写yml
server:
port: 80
eureka:
client:
register-with-eureka: false
service-url:
defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/
#设置feign客户端超时时间(OpenFeign默认支持ribbon)
ribbon:
#指的是建立连接所用的时间,适用于网络状况正常的情况下,两端连接所用的时间
ReadTimeout: 5000
#指的是建立连接后从服务器读取到可用资源所用的时间
ConnectTimeout: 5000
logging:
level:
# feign日志以什么级别监控哪个接口
com.atguigu.springcloud.service.PaymentFeignService: debug
4⃣️主启动:添加@EnableFeignClients注解
5⃣️Service:增加@FeignClient(value = "CLOUD-PAYMENT-SERVICE")
@Component
@FeignClient(value = "CLOUD-PAYMENT-SERVICE")
public interface PaymentFeignService {
@GetMapping(value = "/payment/get/{id}")
public CommonResult getPaymentById(@PathVariable("id") Long id);
@GetMapping(value = "payment/feign/timeout")
public String paymentFeignTimeout();
}
注意⚠️:
- @FeignClient(value = "CLOUD-PAYMENT-SERVICE")表示该借口对应的CLOUD-PAYMENT-SERVICE微服务。通过该注解就可以定位到微服务。
- 该类里面的方法都是来自于服务提供端提供的接口,直接复制过来的。通过@GetMapping注解就可以定位到微服务提供端具体的方法。
6⃣️Controller:注入接口,调用接口实现。
@RestController
@Slf4j
public class OrderFeignController {
@Resource
private PaymentFeignService paymentFeignService;
@GetMapping(value = "/consumer/payment/get/{id}")
public CommonResult<Payment> getPaymentById(@PathVariable("id") Long id){
return paymentFeignService.getPaymentById(id);
}
@GetMapping(value = "/consumer/payment/feign/timeout")
public String paymentFeignTimeout(){
// Openfeign-ribbon,客户端默认等待1秒钟
return paymentFeignService.paymentFeignTimeout();
}
}
7⃣️整个实现的过程:
- 通过Controller类的@GetMapping(value = "/consumer/payment/get/{id}"),调用接口。
- 通过接口的@FeignClient和@GetMapping注解,定位到微服务提供端的方法。
- 调用微服务提供端提供的方法。
3、打印日志功能
1⃣️日志级别
NONE:默认的,不显示任何日志;
BASIC:仅记录请求方法、URL、响应状态码及执行时间;
HEADERS:除了 BASIC 中定义的信息之外,还有请求和响应的头信息;
FULL:除了 HEADERS 中定义的信息之外,还有请求和响应的正文及元数据。
2⃣️配置日志Bean
@Configuration
public class FeignConfig {
@Bean
Logger.Level feignLoggerLevel(){
return Logger.Level.FULL;
}
}
3⃣️YML文件里需要开启日志的Feign客户端
logging:
level:
# feign日志以什么级别监控哪个接口
com.atguigu.springcloud.service.PaymentFeignService: debug
4⃣️启动,后台查看日志