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

开启成功!

相关推荐
乐鑫科技 Espressif17 分钟前
“乐鑫组件注册表”简介
java·前端·microsoft·iot·乐鑫科技
弥琉撒到我28 分钟前
docker对其他中间件镜像拉取多个服务器部署
开发语言·后端·ruby
solomonzw33 分钟前
举例矢量路由协议-RIP
运维·服务器·网络·华为·智能路由器·github
小灰灰__39 分钟前
Java通过calcite实时读取kafka中的数据
java·kafka·linq
java小吕布1 小时前
Java Servlet详解:Servlet的生命周期、请求处理与响应发送
java·开发语言·servlet
小珑也要变强1 小时前
shell中的case语句和循环语句
linux·运维·windows
武子康1 小时前
大数据-225 离线数仓 - 目前需求分析 指标口径 日志数据采集 taildir source HDFS Sink Agent Flume 优化配置
java·大数据·数据仓库·hadoop·hdfs·数据挖掘·flume
世间万物皆对象1 小时前
Spring Boot核心概念:自动配置
java·spring boot·后端
祁思妙想1 小时前
23.<Spring图书管理系统(强制登录版本)>
java·spring·java-ee
csdn5659738501 小时前
Elasticsearch 查看磁盘占用 查看指定索引磁盘占用
java·数据库·elasticsearch