[特殊字符] SpringCloud项目中使用OpenFeign进行微服务远程调用详解(含连接池与日志配置)

📚 目录

  1. 为什么要用OpenFeign?

  2. 在cart-service中整合OpenFeign
    2.1 引入依赖
    2.2 启用OpenFeign
    2.3 编写Feign客户端
    2.4 调用Feign接口

  3. 开启连接池,优化Feign性能
    3.1 引入OkHttp
    3.2 配置启用OkHttp连接池
    3.3 验证连接池生效

  4. Feign最佳实践 —— 客户端抽取
    4.1 避免重复编码问题
    4.2 抽取公共Feign模块
    4.3 配置扫描路径

  5. 配置OpenFeign日志输出

  6. 总结


1. 为什么要用OpenFeign?

在微服务中,服务与服务之间频繁调用。传统使用RestTemplate需要自己管理服务发现、负载均衡、URL拼接,代码复杂且难以维护。

OpenFeign的优势:

  • 声明式接口开发,像调用本地方法一样调用远程服务

  • 内置负载均衡,支持 Ribbon、LoadBalancer

  • 支持连接池,支持超时重试、熔断降级

  • 支持详细日志输出,方便排查问题

一句话总结:OpenFeign让远程调用优雅又高效!


2. 在cart-service中整合OpenFeign

cart-service 查询我的购物车 为例,来演示整合OpenFeign。


2.1 引入依赖

cart-servicepom.xml 中添加:

<!-- OpenFeign -->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency><!-- 负载均衡器 -->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>

2.2 启用OpenFeign

CartApplication 启动类上添加注解:

@EnableFeignClients

表示开启Feign客户端扫描。


2.3 编写Feign客户端

com.hmall.cart.client 包下,新建接口 ItemClient

@FeignClient("item-service")
public interface ItemClient {@GetMapping("/items")List<ItemDTO> queryItemByIds(@RequestParam("ids") Collection<Long> ids);
}

说明:

  • @FeignClient("item-service"):指向要调用的微服务

  • @GetMapping("/items"):对应远程接口路径

  • @RequestParam("ids"):请求参数

  • 返回值会自动封装成List<ItemDTO>


2.4 调用Feign接口

CartServiceImpl 中直接注入 ItemClient,然后调用即可:

@Autowired
private ItemClient itemClient;// 调用
List<ItemDTO> items = itemClient.queryItemByIds(cartItemIds);

✅ 不需要再写 RestTemplate、不需要自己负载均衡,调用清晰简单!


3. 开启连接池,优化Feign性能

默认Feign底层用的是HttpURLConnection,不支持连接池,不适合高并发。

推荐使用 OkHttp 作为Feign底层,提高性能。


3.1 引入OkHttp依赖

cart-servicepom.xml 中添加:

<!-- OKHttp -->
<dependency><groupId>io.github.openfeign</groupId><artifactId>feign-okhttp</artifactId>
</dependency>

3.2 配置启用OkHttp连接池

application.yml 中增加配置:

feign:okhttp:enabled: true

✅ 这样Feign就会自动使用OkHttp作为底层HTTP客户端,并且自动使用连接池。


3.3 验证连接池生效

FeignBlockingLoadBalancerClientexecute 方法打断点调试,可以看到底层已经是 OkHttpClient 了,说明连接池生效了!


4. Feign最佳实践 —— 客户端抽取

未来 trade-service 也需要调用 item-service 的接口,重复定义 ItemClient 显然不合理,需要做客户端抽取


4.1 避免重复编码问题

思路:把公共的Feign客户端抽取出来,供各个微服务引用。


4.2 抽取公共Feign模块

在项目下新建 hm-api 模块,pom.xml配置:

<artifactId>hm-api</artifactId><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-loadbalancer</artifactId></dependency><dependency><groupId>io.swagger</groupId><artifactId>swagger-annotations</artifactId><version>1.6.6</version></dependency>
</dependencies>

然后将 ItemDTOItemClient 移动到 hm-api 模块中。


4.3 配置扫描路径

cart-servicetrade-service 的启动类中添加:

  • 方式一:声明扫描包

@EnableFeignClients(basePackages = "com.hmall.api.client")
  • 方式二:指定特定FeignClient

@EnableFeignClients(clients = {ItemClient.class})

这样就可以正常引用公共模块中的Feign接口了!


5. 配置OpenFeign日志输出

默认OpenFeign日志级别是 NONE,不会打印请求和响应信息。开发测试时开启详细日志很有必要。


5.1 定义日志配置类

hm-api 模块新增配置类:

@Configuration
public class DefaultFeignConfig {@Beanpublic Logger.Level feignLogLevel(){return Logger.Level.FULL;}
}

设置日志级别为 FULL,打印完整请求与响应数据。


5.2 配置日志生效方式

  • 局部生效:在单个 FeignClient 中指定

@FeignClient(value = "item-service", configuration = DefaultFeignConfig.class)
  • 全局生效:在 @EnableFeignClients 中指定

@EnableFeignClients(defaultConfiguration = DefaultFeignConfig.class)

5.3 日志示例

输出示例(查询商品接口):

[ItemClient#queryItemByIds] ---> GET http://item-service/items?ids=1001 HTTP/1.1
[ItemClient#queryItemByIds] ---> END HTTP (0-byte body)
[ItemClient#queryItemByIds] <--- HTTP/1.1 200 (127ms)
...
{"id":1001,"name":"巴布豆拉拉裤","price":67100,"stock":10000,...}

✅ 可以清晰看到请求方法、URL、参数、响应内容,排查问题非常方便!


6. 总结

本篇完整讲解了如何在微服务项目中:

  • 引入OpenFeign

  • 实现声明式远程调用

  • 优化连接池性能(使用OkHttp)

  • 进行Feign客户端抽取复用

  • 配置请求日志,方便开发调试

✅ OpenFeign让我们的微服务调用变得更加优雅、简洁、性能更高。
✅ 配合OkHttp和合理日志配置,是生产级SpringCloud微服务系统必不可少的实践!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/903604.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VARIAN安捷伦真空泵维修清洁保养操作SOP换油操作流程内部转子图文并茂内部培训手侧

VARIAN安捷伦真空泵维修清洁保养操作SOP换油操作流程内部转子图文并茂内部培训手侧

【android bluetooth 案例分析 03】【PTS 测试 】【PBAP/PCE/SSM/BV-10-C】

1. PBAP/PCE/SSM/BV-10-C [PCE Does not share PbapSupportedFeatures bits] 这个 PTS 测试用例 PBAP/PCE/SSM/BV-10-C 的核心目的是验证 PBAP 客户端&#xff08;PCE&#xff09;在与旧版服务器通信时&#xff0c;不会发送 PbapSupportedFeatures 特性位&#xff0c;以确保兼…

批量删除OpenStack实例

在Linux终端实现批量删除OpenStack实例&#xff0c;支持并发删除、安全确认、重试机制、优先清理运行中实例 #!/bin/bash # # 增强版 OpenStack 删除实例脚本 # 功能&#xff1a;支持并发删除、安全确认、重试机制、优先清理运行中实例 # 更新&#xff1a;2025年4月30日 # ##…

# 基于 Python 和 jieba 的中文文本自动摘要工具

基于 Python 和 jieba 的中文文本自动摘要工具 在信息爆炸的时代&#xff0c;快速准确地提取文本核心内容变得至关重要。今天&#xff0c;我将介绍一个基于 Python 和 jieba 的中文文本自动摘要工具&#xff0c;帮助你高效地从长文本中提取关键信息。 一、背景与需求 在处理…

Seaborn数据可视化库

一、Seaborn介绍&#xff1a;基于Matplotlib的Python数据可视化库&#xff0c;专注绘制统计图形&#xff0c;简化可视化过程&#xff0c;提供高级接口和美观默认主题。 二、安装与导入 1.安装&#xff1a;可使用pip install seaborn或conda install seaborn&#xff0c;也可使…

机器视觉2D码垛和机器视觉3D码垛的区别

机器视觉3D码垛是一种结合3D视觉技术和工业机器人的自动化系统,主要用于在复杂环境中精准识别、定位并堆叠(码垛)各种形状、尺寸的物体。它通过3D传感器(如激光雷达、结构光相机、双目视觉等)获取物体的三维空间信息,并结合算法规划机器人的抓取路径和码放策略,实现高效…

Python魔法函数深度解析

一、魔法函数是什么&#xff1f; 魔法函数&#xff08;Magic Methods&#xff09;是Python中以双下划线&#xff08;__xx__&#xff09;包裹的特殊方法&#xff0c;它们为类提供了一种与Python内置语法深度集成的能力。这些方法由解释器自动调用&#xff0c;无需显式调用&…

C++负载均衡远程调用学习之自定义内存池管理

目录 1.内存管理_io_buf的结构分析 2.Lars_内存管理_io_buf内存块的实现 3.buf总结 4.buf_pool连接池的单例模式设计和基本属性 5.buf_pool的初始化构造内存池 6.buf_pool的申请内存和重置内存实现 7.课前回顾 1.内存管理_io_buf的结构分析 ## 3) Lars系统总体架构 ​ …

流水线问题(算法设计)C++

目录 一、需求分析 1.1 问题描述 1.2 数据需求 1.3 功能需求 1.4 开发环境 二、概要设计 2.1 抽象数据类型 ADT 的定义 2.2 系统的主要功能模块 2.3 功能模块联系图 三、详细设计 3.1 数据结构设计 3.2 主要算法 四、系统运行及结果分析 1. 用户界面 2. 程序运行…

从实列中学习linux shell4: shell 脚本中 $0 $1 $2 $3 >> 以及 awk 都是干啥的?

在 Linux Shell 脚本中&#xff0c;这些符号和工具的功能如下&#xff1a; 一、位置参数 $0 $1 $2 $3 符号功能说明示例$0脚本自身的文件名若执行 ./test.sh&#xff0c;则 $0 值为 ./test.sh$1第一个参数执行 ./test.sh apple 时&#xff0c;$1 值为 "apple"$2第二…

TM1668芯片学习心得三

一、键扫数据储存地址如下所示&#xff0c;先发读键命令后&#xff0c;开始读取按键数据BYTE1-BYTE5字节&#xff0c;读数据从低位开始输出&#xff0c;其中B6和B7位为无效位&#xff0c;此时芯片输出为0。芯片K和KS引脚对应的按键按下时&#xff0c;相对应的字节内的 BIT位为1…

MySQL 基本查询(一)

文章目录 Create(insert)指定列的单行插入和全列插入多行全列插入和指定列的多行插入如果主键存在&#xff0c;要插入替换存在的值replace 基本select全列查询指定列查询where子句where子句案例语文成绩在 [80, 90] 分的同学及语文成绩数学成绩是 58 或者 59 或者 98 或者 99 分…

LeetCode路径总和系列问题解析:I、II、III的解决方案与优化

文章目录 引言一、路径总和 I&#xff08;LeetCode 112&#xff09;问题描述方法思路Java代码实现复杂度分析 二、路径总和 II&#xff08;LeetCode 113&#xff09;问题描述方法思路Java代码实现复杂度分析 三、路径总和 III&#xff08;LeetCode 437&#xff09;问题描述方法…

NFC 碰一碰发视频贴牌技术,音频功能的开发实践与技术解析

在数字化营销与信息交互场景中&#xff0c;NFC 碰一碰技术凭借其便捷性和高效性&#xff0c;成为快速传递多媒体内容的新选择。通过 NFC 实现视频音频的快速传输&#xff0c;不仅能提升用户体验&#xff0c;还能为各类场景带来创新应用。本文将深入探讨该功能开发过程中的关键技…

跨境电商生死劫:IP筛查三法则破解封号魔咒

一、血泪数据&#xff1a;90%封号案源于IP污染 跨境电商平台风控系统持续升级&#xff0c;2023年亚马逊全球封号案例中&#xff0c;67%涉及账号关联&#xff08;Marketplace Pulse数据&#xff09;&#xff0c;其中IP问题占比高达91%。更触目惊心的是&#xff1a; 新号存活率&…

MIPS架构详解:定义、应用与其他架构对比

一、MIPS架构的定义 MIPS&#xff08;Microprocessor without Interlocked Pipeline Stages&#xff09; 是一种经典的精简指令集&#xff08;RISC&#xff09;处理器架构&#xff0c;由斯坦福大学John Hennessy团队于1981年提出&#xff0c;强调高效流水线设计和硬件简化。 核…

第十六届蓝桥杯 2025 C/C++组 脉冲强度之和

目录 题目&#xff1a; 题目描述&#xff1a; 题目链接&#xff1a; 思路&#xff1a; 思路详解&#xff1a; 代码&#xff1a; 代码详解&#xff1a; 题目&#xff1a; 题目描述&#xff1a; 题目链接&#xff1a; P12338 [蓝桥杯 2025 省 B/Python B 第二场] 脉冲强度…

从Ping到iperf3:深度实战无线网络压测与优化指南

以下是测试无线网络稳定性的详细步骤与工具指南&#xff0c;涵盖信号质量、吞吐量、干扰排查等关键维度&#xff1a; 一、基础信号质量测试 1. 信号强度与覆盖测试 工具&#xff1a;手机APP&#xff08;WiFi Analyzer、NetSpot&#xff09;或笔记本&#xff08;Acrylic WiFi&a…

MySQL 连接池 (Pool) 常用方法详解

MySQL 连接池 (Pool) 常用方法详解 1. 创建连接池 首先需要创建连接池实例&#xff1a; const mysql require(mysql2/promise); // 使用Promise版本const pool mysql.createPool({host: localhost,user: root,password: password,database: test,waitForConnections: true…

大型连锁酒店集团数据湖应用示例

目录 一、应用前面临的严峻背景 二、数据湖的精细化构建过程 &#xff08;一&#xff09;全域数据整合规划 &#xff08;二&#xff09;高效的数据摄取与存储架构搭建 &#xff08;三&#xff09;完善的元数据管理体系建设 &#xff08;四&#xff09;强大的数据分析平台…