微服务入门篇: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字节码

相关推荐
步、步、为营19 分钟前
.net微服务框架dapr保存和获取状态
微服务·架构·.net
guojl3 小时前
微服务OpenFeign源码分析
spring cloud·微服务
guojl3 小时前
微服务OpenFeign使用手册
spring cloud·微服务
cloudy4914 小时前
Java 各种 IO 模型端口转发性能对比实测(BIO、NIO、AIO、虚拟线程)
java·性能优化
2501_916007474 小时前
iOS 性能测试工具全流程:主流工具实战对比与适用场景
websocket·tcp/ip·http·网络安全·https·udp
阿维的博客日记4 小时前
HTTP/3.0的连接迁移使用连接ID来标识连接为什么可以做到连接不会中断
网络·网络协议·http
半路_出家ren4 小时前
第8章:应用层协议HTTP、SDN软件定义网络、组播技术、QoS
网络·网络协议·http·mpls·qos·sdn软件定义网络·组播技术
teeeeeeemo4 小时前
http和https的区别
开发语言·网络·笔记·网络协议·http·https
修电脑的猫16 小时前
Performance Monitoring on Production Systems in SAP ERP(ABAP性能优化)
性能优化·abap
星辰离彬16 小时前
Java 与 MySQL 性能优化:Java应用中MySQL慢SQL诊断与优化实战
java·后端·sql·mysql·性能优化