SpringCloud OpenFeign负载均衡远程调用 跨服务调用 连接池优化

介绍

Spring Cloud OpenFeign 是 Spring Cloud 的一部分,提供了一种声明式的 HTTP 客户端方式来简化服务间的通信。通过 OpenFeign,开发者可以像调用本地方法一样,轻松地调用远程服务,而不需要手动处理 HTTP 请求、响应和连接等底层细节。

引入依赖

xml 复制代码
<!--openfeign-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
    <version>3.1.3</version>  <!-- Spring Cloud OpenFeign 版本 -->
</dependency>

<!--负载均衡-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-loadbalancer</artifactId>
    <version>3.1.3</version>  <!-- Spring Cloud OpenFeign 版本 -->
</dependency>

启用Openfeign

在启动类上添加@EnableFeignClients

java 复制代码
@SpringBootApplication
@EnableFeignClients
public class Demo3Application {

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

}

远程调用其他服务

定义服务接口

java 复制代码
@FeignClient("java-goods") //要获取哪个服务的数据
public interface GoodsClient {

    @GetMapping("/user/list")
    List<Goods> list();
    
//    List<Goods> list(@RequestParam("ids") List<Long> ids);
//	 传承就这样写

}

接口不用去实现

调用其他服务

java 复制代码
@RestController
@AllArgsConstructor
@RequestMapping("/user")
public class UserController {

    private  final  IUserService userService;
    
    private final GoodsClient goodsClient;
    //远程调用

    @GetMapping("/list")
    public List<User> getList(){
    
        System.out.println(goodsClient.list());
     //远程调用

        return userService.list();
    }

}

连接池优化?

OpenFeign底层发起请求是使用HttpURLConnection发起的,每次连接都需要重新创建导致效率底下。

可以使用第三方框架进行优化

引入连接池

xml 复制代码
<!--openfeign连接池-->
<dependency>
    <groupId>io.github.openfeign</groupId>
    <artifactId>feign-okhttp</artifactId>
    <version>11.6</version>
</dependency>

配置文件

yml 复制代码
feign:
  okhttp:
    enabled: true

开启成功!

相关推荐
恒创科技HK1 分钟前
新站起步,租用香港服务器适合不?
运维·服务器
Henry Zhu1233 分钟前
VPP中的DPDK插件源码详解第三篇:DPDK插件的数据接收和发送
运维·服务器·网络·tcp/ip·计算机网络
budingxiaomoli5 分钟前
初始网络原理
java·运维·服务器·网络
自己的九又四分之三站台6 分钟前
Maven的安装使用
java·maven
回家路上绕了弯6 分钟前
CAP 与 BASE:分布式系统的核心思想与实践指南
分布式·后端
CappuccinoRose9 分钟前
Docker配置过程完整梳理
后端·python·docker·容器·环境配置
Luna-player11 分钟前
Spring整合MyBatis-Pluss 部分课堂学习笔记
java·开发语言·tomcat
I'm Jie11 分钟前
Java 字节码工具 ASM,实现类的动态增强
java·spring boot·spring·asm·cglib·class
ZKNOW甄知科技12 分钟前
低代码 ITSM 知识管理平台:驱动企业数智化运维的新引擎
运维·服务器·人工智能·低代码·网络安全·自动化