目录
- 1.基于Feign的远程调用
- 1.RestTemplate方式调用存在的问题
- 2.Feign的介绍
- 3.定义和使用Feign客户端
- 2.自定义配置
- 1.方式一:配置文件方式
- 2.方式二: java代码方式,需要先声明一个Bean:
- 3.Feign的性能优化
- 1.Feign底层的客户端实现
- 2.连接池配置
- 4.Feign的最佳实践
- 1.方式一(继承)︰
- 2.方式二(抽取)∶
1.基于Feign的远程调用
1.RestTemplate方式调用存在的问题
①代码可读性差,编程体验不统一
②参数复杂URL难以维护
2.Feign的介绍
Feign是一个声明式的http客户端,官方地址:
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
②日志级别,最好用basic
或none
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字节码