微服务入门篇:http客户端Feign(远程调用,自定义配置,Feign的性能优化,Feign服务抽取)

目录

1.基于Feign的远程调用

1.RestTemplate方式调用存在的问题

①代码可读性差,编程体验不统一

②参数复杂URL难以维护

2.Feign的介绍

Feign是一个声明式的http客户端,官方地址:

bash 复制代码
 https://github.com/OpenFeign/feign

其作用就是帮助我们优雅的实现http请求的发送,解决上面提到的问题。

3.定义和使用Feign客户端

1.引入依赖:

2.在order-service的启动类添加注解开启Feign的功能:

3.编写Feign客户端:

修改service层中的服务层代码

使用FeignClient中定义的方法代替RestTemplate:

修改orderservice的yaml:

启动服务,发现服务:

访问order接口,实现Feign的远程调用和负载均衡。

查看源码发现:Feign已经集成了ribbon

2.自定义配置

Feign运行自定义配置来覆盖默认配置,可以修改的配置如下:

一般我们需要配置的就是日志级别。

配置Feign日志:

1.方式一:配置文件方式

1.全局生效:

2.局部生效:

2.方式二: java代码方式,需要先声明一个Bean:

1.而后如果是全局配置,则把它放到@EnableFeignClients这个注解中:

2.如果是局部配置,则把它放到@FeignClient这个注解中:

3.Feign的性能优化

1.Feign底层的客户端实现

URLConnection:默认实现,不支持连接池.

Apache HttpClient :支持连接池

OKHttp:支持连接池
因此优化Feign的性能主要包括:

①使用连接池代替默认的URLConnection

②日志级别,最好用basicnone

2.连接池配置

1.Feign添加HttpClient的支持:

引入依赖:

2.配置连接池:

4.Feign的最佳实践

1.方式一(继承)︰

给消费者的FeignClient和提供者的controller定义统一的父接口作为标准。

2.方式二(抽取)∶

FeignClient抽取为独立模块,并且把接口有关的POJO、默认的Feign配置都放到这个模块中,提供给所有消费者使用

实现步骤如下:

1.首先创建一个module,命名为feign-api,然后引入feign的starter依赖


2.将order-service中编写的UserClient、User、DefaultFeignConfiguration都复制到feign-api项目中

3.在order-service中引入feign-api的依赖

4.修改order-service中的所有与上述三个组件有关的import部分,改成导入feign-api中的包

5.重启测试

当定义的FeignClient不在SpringBootApplication的扫描包范围时,这些FeignClient无法使用

有两种方式解决:

1.方式一:指定FeignClient所在包

1.方式二:指定FeignClient字节码

相关推荐
bluceli2 天前
前端性能优化实战指南:让你的网页飞起来
前端·性能优化
冰_河3 天前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
stark张宇3 天前
微服务架构必备:Gin + gRPC + Consul + Nacos + GORM 打造用户服务
微服务·gin·grpc
不可能的是3 天前
前端 SSE 流式请求三种实现方案全解析
前端·http
叶智辽4 天前
【Three.js内存管理】那些你以为释放了,其实还在占着的资源
性能优化·three.js
BigByte5 天前
我用 6 个 WASM 编码器干掉了 Canvas.toBlob(),图片压缩率直接提升 15%
性能优化·webassembly·图片资源
DemonAvenger6 天前
Kafka性能调优:从参数配置到硬件选择的全方位指南
性能优化·kafka·消息队列
桦说编程6 天前
实战分析 ConcurrentHashMap.computeIfAbsent 的锁冲突问题
java·后端·性能优化
阿里云云原生6 天前
MSE Nacos Prompt 管理:让 AI Agent 的核心配置真正可治理
微服务·云原生
阿里云云原生6 天前
阿里云微服务引擎 MSE 及 API 网关 2026 年 1 月产品动态
微服务