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

开启成功!

相关推荐
Anita_Sun6 分钟前
一看就懂的 Haskell 教程 - 类型推断机制
后端·haskell
java1234_小锋10 分钟前
Java高频面试题:BIO、NIO、AIO有什么区别?
java·面试·nio
Anita_Sun18 分钟前
一看就懂的 Haskell 教程 - 类型签名
后端·haskell
七八星天25 分钟前
C#代码设计与设计模式
后端
用户83071968408225 分钟前
Java IO三大模型(BIO/NIO/AIO)超详细总结
java
sheji341625 分钟前
【开题答辩全过程】以 基于SSM的花店销售管理系统为例,包含答辩的问题和答案
java
Mr_sun.36 分钟前
Day09——入退管理-入住-2
android·java·开发语言
MAGICIAN...1 小时前
【java-软件设计原则】
java·开发语言
砍材农夫1 小时前
threadlocal
后端
JH30731 小时前
为什么switch不支持long
java