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包,而剩余部分就是开启日志功能

相关推荐
巴里巴气4 分钟前
MongoDB数据基本介绍
数据库·mongodb
小鱼人爱编程12 分钟前
Java基石--无处不在的Java Class
java·后端·spring
mini小新30 分钟前
PostgreSQL如何进行跨服务器迁移数据
服务器·数据库·postgresql·数据迁移
JouJz36 分钟前
设计模式之单例模式:深入解析全局唯一对象的艺术
java·开发语言·spring·单例模式·设计模式·面试
不学会Ⅳ36 分钟前
轻量锁偏向锁重量锁害人不浅!synchronized源码!
java·开发语言
01传说37 分钟前
JAVA ---Excel高效导入(去重1000万数据对比)
android·java·excel
阿蒙Amon43 分钟前
C#日期、时间和时区:全球化应用的时间处理艺术
java·服务器·c#
学不动CV了43 分钟前
深入理解C语言内存空间、函数指针(三)(重点是函数指针)
c语言·arm开发·数据库·stm32·单片机·嵌入式硬件·c#
武子康1 小时前
Java-70 深入浅出 RPC Dubbo 详细介绍 上手指南
java·分布式·网络协议·spring·rpc·dubbo·nio
DKPT1 小时前
Java设计模式之行为型模式(命令模式)
java·笔记·学习·设计模式·命令模式