SpringCloud学习:Openfeign组件实现服务调用和负载均衡

OpenFeign:服务调用与负载均衡(服务端接口)

  1. 是什么:通过OpenFeign可以实现服务调用和负载均衡
    1. OpenFeign是一个声明性web服务客户端,
      在这里插入图片描述
  2. 怎么用:服务提供者提取公共接口用@FrignClient标注,服务调用者POM,yml,主启动,然后业务类
    1. 当使用RestTemplate实现服务调用时,要在每个微服务中定义RestTemplate对象,然后手动设置要调用的微服务的名字,再使用该对象对该微服务进行调用;此时每个要调用服务的微服务都要定义一个RestTemplate对象
    2. 为了解决这一问题,引入了OpenFeign:此时只需将服务提供者所提供的方法在公共微服务中相应的接口中声明,并用@FeignClients(‘服务提供者名’)标注该接口(此时公共微服务要引入spring-cloud-starter-openfeign依赖才可使用@FeignClients注解),此时就代表服务提供者将其要提供的服务放到公共的接口中,该接口中的方法必须与所提供的服务方法有一致的路径@XxxMapping(),接口方法名字可以不相同
    3. 服务调用者要调用对应微服务提供的服务时,就可以使用openfrign进行调用首先要在该微服务中引入spring-cloud-starter-openfeignPOM依赖,然后改yml,然后再修改启动类,加入@EnableFeign注解来开启OpenFeign,然后此时在controller中通过自动装配定义要调用服务所提供的接口类对象,然后就可以通过该对象调用对应的方法实现对应的服务
  3. 超时控制:在yml中设置全局或者单个超时时间
    1. 在调用者通过Openfeign调用微服务时,会有两个关于超时的配置,分别是connectTimeout和readTimeout
    2. connectTimeout是调用者连接到提供者的超时控制,而readTimeout是连接上后完成服务调用直到返回所限制的超时时间,默认是60秒,即当服务调用时间超过60s未返回时就会报错
    3. 可以在服务调用者客户端上通过修改yml文件来配置超时时间(谁发起调用就配置谁的yml文件),通过修改 spring.cloud.openfeign.client.config.dafault.readtimeout 来设置全局请求(所有调用请求)的超时控制,也可以单独指定某个服务调用的超时控制,通过修改 spring.cloud.openfeign.client.config.服务名.readtimeout 来实现,两个可以共存,且单个配置会覆盖全局配置
  4. 重试机制:默认是关闭的,只要第一个调用失败则直接返回(在配置类开启重试机制)
    1. 可以开启重试机制,当调用失败后会重新发起请求
    2. 在调用者客户端微服务中创建FeignConfig配置类@Configuration注解标注,然后用@Bean注解标注 Retry myRetry(){} 方法,在该方法中默认 return Retry.NEVER_RETRY;(默认是不进行重试的),此时可以修改return Retry.default(初次间隔时间,最大间隔时间,请求总次数)来开启重试机制,此时当第一次请求失败后,会间隔时间后重新发起调用请求,直到规定次数失败后才会返回报错
  5. 性能优化HttpClient5:一定要替换!!先引入POM依赖再在yml中进行配置
    1. OpenFeign默认使用JDK中自带的HttpClient.HttpURLConnection发送HTTP请求,没有连接池、性能和效率也比较低,此时就可以修改OpenFeign的连接
    2. 此时可以使用Apache 的HttpClient5来替换以提高性能,先修改POM中的依赖,导入HC5的依赖,然后修改调用者的yml配置文件spring.cloud.openfeign.httpclient.hc5.enabled=true,以开启HC5来替换默认的HttpClient
  6. 请求回应压缩:直接在yml中开启压缩
    1. 使用OpenFeign进行服务调用时可以对请求和回应进行GZIP压缩,以减少通信过程中性能损耗,要通过参数 **spring.cloud.openfeign.compression.request/response.enabled=true 来开启请求和回应的数据压缩
  7. 日志打印:对Feign的接口调用情况进行监控和输出先在配置类开启日志级别,再在yml中配置对哪个接口进行监控
    1. 先在配置类开启日志级别,再在yml中配置对哪个接口进行监控
    2. 首先要在需要开启日志功能的客户端微服务中的FeignConfig配置类中配置@Bean:Logger.Level返回所选择开启的日志级别Logger.Level.Xxx,然后在yml配置文件中开启日志功能提供设置logging.level.含有@FeignClient注解的接口的完整包名和接口名=debug表示开启日志监控哪个接口的调用情况![[Pasted image 20241011152041.png]]
    3. OpenFeign提供日志打印功能,了解请求的细节,对Feign的接口调用情况进行监控和输出,有四个日志级别:NULL、BASIC、HEADER、FULL,默认是NULL不会记录任何日志信息,BASIC记录了请求的url、请求方法等信息,HEADER记录了请求和响应的头信息,FULL全部信息都记录了正文和元数据等

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

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

相关文章

kernel32.dll下载地址:如何安全地恢复系统文件

关于从网络上寻找kernel32.dll的下载地址,这通常不是一个安全的做法,而且可能涉及到多种风险。kernel32.dll是Windows操作系统的核心组件之一,负责内存管理、进程和线程管理以及其他关键系统功能。因为kernel32.dll是系统的基础文件&#xff…

信息安全工程师(57)网络安全漏洞扫描技术与应用

一、网络安全漏洞扫描技术概述 网络安全漏洞扫描技术是一种可以自动检测计算机系统和网络设备中存在的漏洞和弱点的技术。它通过使用特定的方法和工具,模拟攻击者的攻击方式,从而检测存在的漏洞和弱点。这种技术可以帮助组织及时发现并修补漏洞&#xff…

【数据结构与算法】链表(上)

记录自己所学&#xff0c;无详细讲解 无头单链表实现 1.项目目录文件 2.头文件 Slist.h #include <stdio.h> #include <assert.h> #include <stdlib.h> struct Slist {int data;struct Slist* next; }; typedef struct Slist Slist; //初始化 void SlistI…

C++20中头文件ranges的使用

<ranges>是C20中新增加的头文件&#xff0c;提供了一组与范围(ranges)相关的功能&#xff0c;此头文件是ranges库的一部分。包括&#xff1a; 1.concepts: (1).std::ranges::range:指定类型为range&#xff0c;即它提供开始迭代器和结束标记(it provides a begin iterato…

系统托盘图标+快捷启动(Python)

QkStart 我把这个程序命名为QkStart 代码 # -*- coding: utf-8 -*- # Environment PyCharm # File_name QkStart |User Pfolg # 2024/10/19 22:06 import threading import time import pystray from PIL import Image from pystray import MenuItem, Menu import o…

leetcode.204.计数质数

#中等#枚举 给定整数 n &#xff0c;返回 所有小于非负整数 n 的质数的数量 。 埃氏筛 枚举没有考虑到数与数的关联性&#xff0c;因此难以再继续优化时间复杂度。接下来我们介绍一个常见的算法&#xff0c;该算法由希腊数学家厄拉多塞&#xff08;Eratosthenes&#xff09;提…

文字跑马灯:实现文字自动滚动策略的原理分析

一. 背景 在前端开发中&#xff0c;不少网站和应用都会运用到动态效果来吸引用户的注意&#xff0c;并提升用户体验。文字跑马灯是一种常见的动态效果&#xff0c;通过文字不断滚动来展示内容&#xff0c;吸引用户的注意力。 最近的一个项目就需要实现文字跑马灯效果&#xf…

【消息队列】RabbitMQ实现消费者组机制

目录 1. RabbitMQ 的 发布订阅模式 2. GRPC 服务间的实体同步 2.1 生产者服务 2.2 消费者服务 3. 可靠性 3.1 生产者丢失消息 3.2 消费者丢失消息 3.3 RabbitMQ 中间件丢失消息 1. RabbitMQ 的 发布订阅模式 https://www.rabbitmq.com/tutorials/tutorial-three-go P 生…

基于SpringBoot+Vue+uniapp微信小程序的乡村政务服务系统的详细设计和实现(源码+lw+部署文档+讲解等)

项目运行截图 技术框架 后端采用SpringBoot框架 Spring Boot 是一个用于快速开发基于 Spring 框架的应用程序的开源框架。它采用约定大于配置的理念&#xff0c;提供了一套默认的配置&#xff0c;让开发者可以更专注于业务逻辑而不是配置文件。Spring Boot 通过自动化配置和约…

【软件测试】JUnit

Junit 是一个用于 Java 编程语言的单元测试框架&#xff0c;Selenium是自动化测试框架&#xff0c;专门用于Web测试 本篇博客介绍 Junit5 文章目录 Junit 使用语法注解参数执行顺序断言测试套件 Junit 使用 本篇博客使用 Idea集成开发环境 首先&#xff0c;创建新项目&#…

VUE 仿神州租车-开放平台

项目背景&#xff1a; 神州租车是一家提供汽车租赁服务的公司&#xff0c;其API开放平台为开发者提供了访问神州租车相关服务和数据的接口。用VUE技术来仿照其开发平台。 成果展示&#xff1a; 首页&#xff1a; API文档&#xff1a; 关于我们&#xff1a;

牛只行为及种类识别数据集18g牛只数据,适用于多种图像识别,目标检测,区域入侵检测等算法作为数据集。数据集中包括牛只行走,站立,进食,饮水等不同类型的数据

18g牛只数据&#xff0c;适用于多种图像识别&#xff0c;目标检测&#xff0c;区域入侵检测等算法作为数据集。 数据集中包括牛只行走&#xff0c;站立&#xff0c;进食&#xff0c;饮水等不同类型的数据&#xff0c;可以用于行为检测 数据集中包含多种不同种类的牛只&#xff…

黑盒测试 | 挖掘.NET程序中的反序列化漏洞

通过不安全反序列化漏洞远程执行代码 今天&#xff0c;我将回顾 OWASP 的十大漏洞之一&#xff1a;不安全反序列化&#xff0c;重点是 .NET 应用程序上反序列化漏洞的利用。 &#x1f4dd;$ _序列化_与_反序列化 序列化是将数据对象转换为字节流的过程&#xff0c;字节流可以…

基于SpringBoot+Vue+uniapp的诗词学习系统的详细设计和实现

详细视频演示 请联系我获取更详细的演示视频 项目运行截图 技术框架 后端采用SpringBoot框架 Spring Boot 是一个用于快速开发基于 Spring 框架的应用程序的开源框架。它采用约定大于配置的理念&#xff0c;提供了一套默认的配置&#xff0c;让开发者可以更专注于业务逻辑而不…

Maxwell 底层原理 详解

Maxwell 是一个 MySQL 数据库的增量数据捕获&#xff08;CDC, Change Data Capture&#xff09;工具&#xff0c;它通过读取 MySQL 的 binlog&#xff08;Binary Log&#xff09;来捕获数据变化&#xff0c;并将这些变化实时地发送到如 Kafka、Kinesis、RabbitMQ 或其他输出端。…

0x3D service

0x3D service 1. 概念2. Request message 数据格式3. Respone message 数据格式3.1 正响应格式3.2 negative respone codes(NRC)4. 示例4.1 正响应示例:4.2 NRC 示例1. 概念 UDS(统一诊断服务)中的0x3D服务,即Write Memory By Address(按地址写内存)服务,允许客户端向服…

2024年中国工业大模型行业发展研究报告|附43页PDF文件下载

工业大模型伴随着大模型技术的发展&#xff0c;逐渐渗透至工业&#xff0c;处于萌芽阶段。 就大模型的本质而言&#xff0c;是由一系列参数化的数学函数组成的计算系统&#xff0c;且是一个概率模型&#xff0c;其工作机制是基于概率和统计推动进行的&#xff0c;而非真正的理解…

aardio 中最重要的控件:自定义控件使用指南

aardio虽然是个小众编程语言&#xff0c;但其在windows下做个小软件生成exe文件&#xff0c;确实方便。只是这个编程语言的生态圈小&#xff0c;文档的详细程度也完全无法和大的编程语言相提并论。今天介绍一下&#xff0c;aardio中的自定义控件如何使用。 这里我们只介绍如何做…

python 作业1

任务1: python为主的工作是很少的 学习的python的优势在于制作工具&#xff0c;制作合适的工具可以提高我们在工作中的工作效率的工具 提高我们的竞争优势。 任务2: 不换行 换行 任务3: 安装pycharm 进入相应网站Download PyCharm: The Python IDE for data science and we…

AnaTraf | TCP重传的工作原理与优化方法

目录 什么是TCP重传&#xff1f; TCP重传的常见触发原因 TCP重传对网络性能的影响 1. 高延迟与重传 2. 吞吐量的下降 如何优化和减少TCP重传 1. 优化网络设备配置 2. 优化网络链路 3. 网络带宽的合理规划 4. 部署CDN和缓存策略 结语 AnaTraf 网络性能监控系统NPM | …