【微服务】 OpenFeign

OpenFeign

OpenFeign

OpenFeign是一个声明式的http客户端,是SpringCloud在Eureka公司开源的Feign基础上改造而来

地址: https://github.com/OpenFeign/feign

  • 作用:

基于SpringMVC的常见注解,简化RestTemplate的http请求的发送

OpenFeign的使用

  1. 引入依赖,包括OpenFeign和负载均衡的组件SpringCloudLoadBalancer
java 复制代码
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-loadbalancer</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
  1. 通过注解 @EnableFeignClients启动OpenFeign功能,添加在启动类上
  2. 编写FeignClient
java 复制代码
@FeignClient(value="服务名称")
public interface testClient{
     @GetMapper("/test")
     List<User> test(@RequestParam("id") Collection<Long> id);
}
  1. 使用FeignClient,实现远程调用
java 复制代码
List<User> test = testclient.test(List.of(1,2,3));

连接池

OpenFeign的底层是使用Client发送请求的,Client每次发送请求需要不断地重复创建连接,我们可以该换底层发送请求的框架:
HttpURLConnection:默认实现,不支持连接池
Apache HttpClient:支持连接池
OKHttp:支持连接池

  • 该换OKHttp
  1. 引入依赖
java 复制代码
<dependency>
   <groupId>io.github.openfeign</groupId>
   <artifactId>feign-okhttp</artifactId>
</dependency>
  1. 开启连接池功能
yml 复制代码
feign:
  okhttp:
     enabled: true #开启连接池支持

配置完成之后底层就会改变为OKHttp来发送请求

日志

OpenFeign只会在FeignClient所在的包的日志级别为DEBUG时,才会输出日志,而且日志级别由四级:
NONE:不记录任何日志信息,还是默认值
BASIC:仅记录请求的方式,URL以及响应状态码和执行时间
HEADERS:在BASIC的基础上,额外记录了请求和响应的头信息
FULL:记录所有请求和响应的明细,包括头信息,请求体,元数据

由于Feign默认的日志级别就是NONE,所以默认我们看不到请求日志

如果要更改默认的日志级别需要自定义日志级别的Bean

java 复制代码
@Bean
public class test{
  @Bean
  public Logger.Level feignLogLevel(){
     return Logger.Level.Full;
  }
}

再将上述的Bean放在注解 @FeignClient中使其生效

java 复制代码
@FeignClient(value="服务名称",configuration=test.Class)

不过这样只会对某个客户端有效,如果想进行全局的配置

java 复制代码
@EnableFeignClients(defaultConfiguration=DefaultFeignConfig.calss)

注解放在启动类上就可以开启日志

相关推荐
GeminiJM1 天前
亿级向量检索:Elasticsearch vs. Milvus,性能鸿沟与架构抉择
elasticsearch·架构·milvus
上海云盾第一敬业销售1 天前
主流DDoS防护技术架构解析与实战经验
架构·ddos
珑墨1 天前
【架构】前端 pnpm workspace详解
前端·架构
Clarence Liu1 天前
k8s 1.35 使用kubeadm部署高可用集群
云原生·容器·kubernetes
麦兜*1 天前
深入解析云原生AI应用全栈架构:从Kubernetes智能调度与Istio服务网格到Knative事件驱动与Prometheus可观测性实战指南
人工智能·云原生·架构
晚霞的不甘1 天前
Flutter for OpenHarmony字典查询 App 全栈解析:从搜索交互到详情展示的完整实
flutter·架构·前端框架·全文检索·交互·个人开发
摆烂z1 天前
k8s频繁拉取镜像导致磁盘占满imagefs
云原生·容器·kubernetes
xdpcxq10291 天前
解密 Navicat 密码神器NavicatPassword 技术实现与架构解析
架构
牛奶咖啡131 天前
Prometheus+Grafana构建云原生分布式监控系统(十一)_基于consul的服务发现
云原生·prometheus·consul的安装部署·consul服务自动发现·consul服务的注册删除·consul服务的更新·实现自动去consul注册服务
虫小宝1 天前
基于 OAuth2 与淘宝开放平台 API 的安全授权与数据同步机制设计
微服务·云原生·架构