Spring Cloud-Feign

Feign是一个声明式的HTTP客户端,它简化了HTTP请求的实现,解决了RestTemplate的不足。Feign通过集成Ribbon实现负载均衡,提供了多种日志级别进行调试。相比RestTemplate,Feign的使用更简洁,性能更优。在配置中,可以调整日志级别以监控请求细节,并通过设置连接池参数来优化性能。此外,文章还介绍了如何抽取FeignClient的具体实现步骤,为实际开发提供了指导。

Fegin是一个声明式的http客户端,官方地址:https://github.com/OpenFeign/feign
其作用就是帮助我们优雅的实现http请求的发送,解决RestTemplate的弊端问题。

一、Feign替代RestTemplate

1、RestTemplate方式调用存在的问题:
在这里插入图片描述
2、定义和使用Feign客户端:
在这里插入图片描述
在这里插入图片描述
3、对比RestTemplate和Feign的使用如下:
在这里插入图片描述
在这里插入图片描述
注意:
  Feign自动集成了Ribbon完成负载均衡,可通过包的路径看到spring-cloud-openfile-core包下面有spring-cloud-netfilx-ribbon包。

4、Feign的使用步骤:
在这里插入图片描述

二、自定义配置

在这里插入图片描述
1、日志级别:
(1)NONE:没有任何日志,默认级别。
(2)BASIC:基本信息日志,请求什么时候发的,什么时候结束以及耗时多久等基本信息。
(3)HEADERS:请求基本信息以及请求头和响应头。
(4)FULL:请求基本信息以及请求头和响应头,请求体和响应体,这是最完整的日志。调试错误时适合使用(一般不采用,因为日志也是会消耗性能)。

2、配置Feign日志:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

三、Feign使用优化

1、Feign的性能优化:
在这里插入图片描述
2、连接池配置:
在这里插入图片描述
在这里插入图片描述

四、最佳实践

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
抽取FeignClient具体实现步骤:在这里插入图片描述
在这里插入图片描述
本文图片来自视频学习过程中所截,主要用于个人复习,视频来源:https://www.bilibili.com/video/BV1LQ4y127n4

`spring-cloud-starter-feign` 是早期版本中使用的依赖名称,但在 Spring Cloud 的后续版本中已经被废弃。取而代之的是 `spring-cloud-starter-openfeign`[^3]。 如果需要在 Maven 项目中引入 OpenFeign 支持,则应在项目的 `pom.xml` 文件中添加如下依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> ``` 需要注意的是,OpenFeign 已经成为 Spring Cloud 的一部分,并且默认集成了与 Spring Boot 和 Spring MVC 的良好兼容性。因此无需再单独寻找 `spring-cloud-starter-feign` 这一旧版依赖[^4]。 此外,为了确保项目的正常运行,还需要确认所使用的 Spring Cloud 版本号是否匹配当前的 Spring Boot 版本。可以在 `pom.xml` 中定义 Spring Cloud BOM(Bill of Materials),以便管理所有相关依赖的版本一致性。例如: ```xml <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Hoxton.SR12</version> <!-- 替换为适合您项目的版本 --> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> ``` 最后,当使用 Feign 或 OpenFeign 时,通常会结合 Eureka 或 Consul 等服务注册中心来实现动态的服务发现功能。这可以通过启用相应的注解完成,比如 `@EnableDiscoveryClient` 或者 `@EnableEurekaClient`。 ### 示例代码 以下是完整的 Maven 配置示例: ```xml <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.7.5</version> <!-- 根据实际需求调整版本 --> <relativePath/> <!-- lookup parent from repository --> </parent> <properties> <java.version>11</java.version> </properties> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Hoxton.SR12</version> <!-- 使用合适的 Spring Cloud 版本 --> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> <dependency> <groupId>io.github.openfeign</groupId> <artifactId>feign-httpclient</artifactId> </dependency> </dependencies> </project> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值