0


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

目录

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字节码
在这里插入图片描述


本文转载自: https://blog.csdn.net/qq_61888137/article/details/136048865
版权归原作者 JungleiRim 所有, 如有侵权,请联系我们删除。

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

还没有评论