Feign进行微服务转发的实现

1.导包,如果需要开启日志,还需要修改配置文件

java 复制代码
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
        <dependency>
            <groupId>io.github.openfeign</groupId>
            <artifactId>feign-okhttp</artifactId>
            <version>11.8</version>
        </dependency>

第一个包是feign的启动类

第二个包比较重要:主要就是打开http的池化功能,减少连接的消耗

  • 替换默认 HTTP 客户端

    • Feign 默认使用 JDK 的 HttpURLConnection 作为底层 HTTP 客户端。

    • 如果你引入了 feign-okhttp,Feign 会自动检测并切换到 OkHttp 作为 HTTP 实际调用器。

  • 性能和功能优势

    • 连接池 :OkHttp 内建高效的连接复用与长连接管理,比 HttpURLConnection 的连接复用更稳定。

    • 异步调用:支持同步和异步请求,便于在必要时进行非阻塞 I/O。

    • 更丰富的配置:可以灵活控制超时、重试、拦截器、拦截器链、请求缓存等高级功能。

    • 更好的日志与调试:通过 OkHttp 的拦截器,能够非常方便地对请求/响应进行统一加工、日志、签名、Mock 等操作。

2.配置client

在我学习的项目中,单独拆分一个api模块,该模块用于存放公用工具以及各种服用模块,client自然也放在其中,这算是横向拆分的一种。我的项目按照功能拆分,所以总体是纵向拆分,从这体现出纵向拆分与横向拆分是互补共存的。

配置client采取feign的类似于SpringMVC的形式来调用远程微服务接口,比如:

java 复制代码
@FeignClient(value = "cart-service")
public interface CartClient {
    @DeleteMapping("/carts")
    public void deleteCartItemByIds(@RequestParam("ids") Collection<Long> ids);
}

value需要填写调用的微服务名称,这个名称是在配置文件中定义的,片段配置文件如下:

javascript 复制代码
server:
  port: 8082
spring:
  application:
    name: cart-service
  profiles:
    active: dev
  cloud:
    nacos:
      server-addr: 127.0.0.1:8848
      config:
        import-check:
          enabled: false  # 暂时禁用导入检查
      discovery:
        enabled: true
        namespace: public
        cluster-name: DEFAULT
        group: DEFAULT_GROUP

3.重点,容易遗忘的一点:假设A模块调用B模块的内容,调用过程是A请求client,client通过网络连接请求B,B执行对应接口内容,返回A具体执行结果。

但是问题是,现在的client存放在单独的复用模块,在我的项目中命名为api模块,那么api模块是不需要去启动的,那么A模块如何去自动注入client代理的实例?显然需要让A模块找到需要的client对象。

所以,一定不要忘记去在A模块的启动项中添加扫描feign对应client的注解!!!!

java 复制代码
@SpringBootApplication
@MapperScan("com.hxy.cartservice.mapper")
@EnableDiscoveryClient
@EnableFeignClients(basePackages = "com.hxy.hmapi.client",defaultConfiguration = {DefaultFeignConfig.class})
public class CartServiceApplication {

    public static void main(String[] args) {
        SpringApplication.run(CartServiceApplication.class, args);
    }
}

这里的@EnableFeignClients(basePackages = "com.hxy.hmapi.client",defaultConfiguration = {DefaultFeignConfig.class})标红部分就是标记对应client包,而剩余部分就是开启日志功能

相关推荐
77qqqiqi26 分钟前
解决忘记修改配置密码而无法连接nacos的问题
java·数据库·docker·微服务
ALLSectorSorft39 分钟前
相亲小程序用户注册与登录系统模块搭建
java·大数据·服务器·数据库·python
琢磨先生David1 小时前
Java 垃圾回收机制:自动化内存管理的艺术与科学
java
Cyber4K1 小时前
MySQL--组从复制的详解及功能演练
运维·数据库·mysql·云原生
tangchao340勤奋的老年?1 小时前
[Qt]QString 与Sqlite3 字符串互动[汉字不乱码]
数据库·sqlite
netho01 小时前
nuxt3: trpc-nuxt和sqlite导致的503错误
数据库·sqlite·vue·nuxt
岁忧1 小时前
(nice!!!)(LeetCode 每日一题) 2561. 重排水果 (哈希表 + 贪心)
java·c++·算法·leetcode·go·散列表
阿华的代码王国2 小时前
【Android】RecyclerView实现新闻列表布局(1)适配器使用相关问题
android·xml·java·前端·后端
码农BookSea2 小时前
自研 DSL 神器:万字拆解 ANTLR 4 核心原理与高级应用
java·后端
lovebugs2 小时前
Java并发编程:深入理解volatile与指令重排
java·后端·面试