当前位置: 首页 > news >正文

【Feign】 基于 Feign 远程调用、 自定义配置、性能优化、实现 Feign 最佳实践


在这里插入图片描述

🐌个人主页: 🐌 叶落闲庭
💨我的专栏:💨
SpringCloud
MybatisPlus
JVM

石可破也,而不可夺坚;丹可磨也,而不可夺赤。


Feign

  • 一、 基于 Feign 远程调用
    • 1.1 RestTemplate方式存在的问题
    • 1.2 Feign 的介绍
    • 1.3 定义和使用Feign客户端
  • 二、 自定义配置
    • 2.1 配置Feign日志(配置文件方式)
    • 2.2 配置Feign日志(Java代码方式)
  • 三、 性能优化
    • 3.1 Feign 底层客户端实现
    • 3.2 Feign的性能优化(连接池配置)
  • 四、 实现 Feign 最佳实践
    • 4.1 新建module,命名feign-api,然后引入feign的starter依赖
    • 4.2 将order-service中编写的UserClient、User、DefaultFeignConfiguration都复制到feign-api项目中
    • 4.3 在order-service中引l入feign-api的依赖
    • 4.4 修改order-service中的所有与上述三个组件有关的import部分,改成导入feign-api中的包

一、 基于 Feign 远程调用

1.1 RestTemplate方式存在的问题

之前利用RestTemplate发起远程调用需要拼接字符串的形式传递url地址,通过这个url地址指明服务名称和请求路径以及请求参数信息,然后传递请求方式和返回值类型,由RestTemplate向这个指定地址发起请求,再把这个结果转成对应类型。

String url = "http://userservice/user/" + order.getUserId();
User user = restTemplate.getForObject(url, User.class);

通过RestTemplate发送http请求的方式代码可读性差,编程体验不统一,若是参数非常多就会导致URL参数复杂,难以维护。

1.2 Feign 的介绍

Feign 是一个声明式的http客户端,声明式就相当于MySQL中的事务一样,在Spring中要开启事务,不需要手动打开或关闭,只需要在配置文件中声明事务,Spring就会自动实现事务,同样声明式http客户端也是如此,Feign可以帮助我们优雅的实现http请求的发送。

1.3 定义和使用Feign客户端

  • 1.引入依赖
<!--feign客户端依赖-->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
  • 2.在启动类添加注解@EnableFeignClients开启Feign功能
@SpringBootApplication
@EnableFeignClients(defaultConfiguration = FeignClientConfiguration.class)
public class OrderApplication {public static void main(String[] args) {SpringApplication.run(OrderApplication.class, args);}
}
  • 3.编写Feign客户端
@FeignClient("userservice")
public interface UserClient {@GetMapping("/user/{id}")User findById(@PathVariable("id") Long id);
}
  • 服务名称:userservice
  • 请求方式:GET
  • 请求路径:/user/{id}
  • 请求参数:Long id
  • 返回值类型:User

  • 4.发送http请求
@Service
public class OrderService {@Autowiredprivate OrderMapper orderMapper;@Autowiredprivate UserClient userClient;public Order queryOrderById(Long orderId) {// 1.查询订单Order order = orderMapper.findById(orderId);//2.用feign远程调用User user = userClient.findById(order.getUserId());//封装user到orderorder.setUser(user);// 4.返回return order;}
}

二、 自定义配置

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

类型作用说明
feign.Logger.Level修改日志级别包含四种不同的级别:NONE、BASIC、HEADERS、FULL
feign.codec.Decoder相应结果的解析器http远程调用的结果做解析,例如解析json字符串为java对象
feign.codec.Encoder请求参数编码将请求参数编码,便于通过http请求发送
feign.Contract支持的注解格式默认是SpringMVC的注解
feign.Retryer失败重试机制请求失败的重试机制,默认是没有,不过会使用Ribbont的重试

一般配置的只是日志级别

2.1 配置Feign日志(配置文件方式)

打开服务的配置文件,添加Feign的配置

  • 全局生效:
feign:client:config:default:	# 默认全局配置loggerLevel: FULL	# 打开全部日志
  • 局部生效:
feign:client:config:userservice:	# 针对 userservice 服务loggerLevel: FULL	# 打开全部日志

2.2 配置Feign日志(Java代码方式)

  • 声明bean
public class FeignClientConfiguration {@Beanpublic Logger.Level logLevel() {return Logger.Level.BASIC;}
}
  • 若是全局配置,则把它放到@EnableFeignClients这个注解中
@EnableFeignClients(defaultConfiguration = FeignClientConfiguration.class)
  • 若是局部配置,则把它放到@FeignClient这个注解中
@FeignClient(value = "userservice",configuration = FeignClientConfiguration.class)

三、 性能优化

3.1 Feign 底层客户端实现

  • URLConnection:默认实现,不支持连接池
  • Apache HttpClient:支持连接池
  • OKHttp:支持连接池
    优化Feign的性能主要包括:
    1. 使用连接池代替潜默认的URLConnection
    1. 日志级别,最好用 basic 或 none

3.2 Feign的性能优化(连接池配置)

  • Feign中添加HttpClient的支持,引入依赖:
<!--引入HttpClient依赖-->
<dependency><groupId>io.github.openfeign</groupId><artifactId>feign-httpclient</artifactId>
</dependency>
  • 配置连接池:
feign:client:config:default:  # 默认全局配置loggerLevel: BASIC  # 日志级别,BASIC是最基本的请求和响应httpclient:enabled: true # 支持HttpClient的开关max-connections: 200 # 最大连接数max-connections-per-route: 50 # 单个路径最大连接数

四、 实现 Feign 最佳实践

4.1 新建module,命名feign-api,然后引入feign的starter依赖

  • 新建模块:

在这里插入图片描述


在这里插入图片描述


  • 引入feign的starter依赖:
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId><version>2.2.1.RELEASE</version>
</dependency>>

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


在这里插入图片描述


在这里插入图片描述


4.3 在order-service中引l入feign-api的依赖

<!--引入统一feign-api-->
<dependency><groupId>cn.itcast.demo</groupId><artifactId>feign-api</artifactId><version>1.0</version>
</dependency>

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

import cn.itcast.feign.pojo.User;
import cn.itcast.feign.clients.*;
  • 当定义的FeignClient不在SpringBootApplication的扫描包范围时,这些FeignClient无法使用。有两种方式解决:
  • 方式一:指定FeignClient)所在包
@EnableFeignClients(basePackages = "cn.feign.clients")
  • 方式二:指定FeignClient字节码(推荐)
@EnableFeignClients(clients = UserClient.class)

在这里插入图片描述


http://www.lryc.cn/news/236171.html

相关文章:

  • 小迪安全笔记(3)——基础入门3、基础入门4
  • SOME/IP 协议介绍(六)接口设计的兼容性规则
  • 吴恩达《机器学习》8-5->8-6:特征与直观理解I、样本与值观理解II
  • 『亚马逊云科技产品测评』活动征文|借助AWS EC2搭建服务器群组运维系统Zabbix+spug
  • 文件转换,简简单单,pdf转word,不要去找收费的了,自己学了之后免费转,之后就复制粘贴就ok了
  • Jmeter——循环控制器中实现Counter计数器的次数重置
  • [创业之路-85]:IT创业成功老板的品质、创业失败老板的特征、成功领导者的品质、失败管理者的特征
  • 警惕.360勒索病毒,您需要知道的预防和恢复方法。
  • 人力资源小程序
  • 【多线程 - 10、线程同步3 ThreadLocal】
  • 【Flink 问题集】The generic type parameters of ‘Collector‘ are missing
  • 数据分析—将txt文件转为csv文件;将csv文件转为xls文件
  • 【算法】二分查找-20231120
  • WPF实现将鼠标悬浮在按钮上时弹出菜单
  • 车载以太网-传输层-UDP
  • uniapp如何上传文件,使用API是什么
  • 【狂神说Java】Docker概述 | Docker安装 | Docker的常用命令
  • Git精讲
  • 读书笔记:Effective C++ 3.0版2005年Scott Meyers : 55条建议(47-55)
  • Golang Context 的并发安全性探究
  • C++中只能有一个实例的单例类
  • 单张图像3D重建:原理与PyTorch实现
  • 340条样本就能让GPT-4崩溃,输出有害内容高达95%?OpenAI的安全防护措施再次失效
  • 2023.11.17使用flask将多个图片文件上传至服务器
  • 母婴服务预约小程序的效果如何
  • Flask实现cookie 开发
  • 2311rust,到60版本更新
  • 【开源】基于Vue和SpringBoot的微信小程序的音乐平台
  • adb手机调试常用命令
  • IDEA常用插件合集