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
②日志级别,最好用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字节码
在这里插入图片描述

Logo

更多推荐