【微服务】微服务之Feign 与 Ribbon

文章目录

      • 强烈推荐
      • 引言
      • 优点
      • Feign示例
      • 什么是Ribbon?
      • Ribbon 的优点
      • Netflix Feign 和 Ribbon整合
        • Feign 与 Ribbon 的关系
        • Feign 与 Ribbon 结合使用的示例
        • 配置文件(application.yml)
        • 说明:
      • Feign 与 Ribbon 结合使用的应用场景
        • 1. 动态服务发现与调用
        • 2. 负载均衡
        • 3. 服务熔断与重试
        • 4. 服务降级
      • 总结
      • 强烈推荐
      • 专栏集锦
      • 写在最后

579a429daf314744b995f37351b46548

强烈推荐

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站:人工智能

b004071ozy_05_amzn


引言

Netflix Feign 是一个声明式的 HTTP 客户端,用于简化微服务之间的 HTTP 请求。

Feign 通过注解来定义服务接口,并自动生成实现代码,从而减少了手工编写 HTTP 客户端的代码量。

它是 Netflix 开源软件套件的一部分,通常与 Spring Cloud 一起使用,以简化微服务架构中的服务调用。


优点

  1. 简化代码

    Feign 使用注解来声明 HTTP 请求,简化了代码编写和维护。开发人员只需定义接口和方法,Feign 会自动生成请求代码。

  2. 集成性好

    Feign 可以与其他 Netflix 开源组件(如 Eureka 和 Ribbon)无缝集成,从而实现服务发现和负载均衡。

  3. 可扩展性强

    Feign 提供了许多自定义功能,可以方便地扩展和定制,如日志记录、错误处理、编码和解码等。

  4. 支持多种编解码器

    Feign 支持多种编解码器(如 JSON、XML),并且可以通过自定义编解码器来支持其他格式。

  5. 支持 Spring Cloud

    Feign 与 Spring Cloud 紧密集成,可以轻松地在 Spring Boot 应用中使用。Spring Cloud Feign 提供了与 Spring Boot 环境的完美结合,使开发人员可以更方便地实现微服务调用。

  6. 灵活的配置

    Feign 支持通过配置文件和注解来灵活地配置请求参数、头信息、超时设置等。


Feign示例

import feign.Feign;
import feign.gson.GsonDecoder;
import feign.gson.GsonEncoder;
import feign.Logger;
import feign.slf4j.Slf4jLogger;
import feign.RequestLine;public class Example {public interface GitHub {@RequestLine("GET /repos/{owner}/{repo}/contributors")List<Contributor> contributors(@Param("owner") String owner, @Param("repo") String repo);}public static class Contributor {String login;int contributions;}public static void main(String... args) {GitHub github = Feign.builder().decoder(new GsonDecoder()).encoder(new GsonEncoder()).logger(new Slf4jLogger(GitHub.class)).logLevel(Logger.Level.FULL).target(GitHub.class, "https://api.github.com");List<Contributor> contributors = github.contributors("OpenFeign", "feign");for (Contributor contributor : contributors) {System.out.println(contributor.login + " (" + contributor.contributions + ")");}}
}

什么是Ribbon?

Ribbon 是 Netflix 开源的一个客户端负载均衡器,通常与微服务架构中的服务发现机制(如 Eureka)配合使用。

它负责在多个服务实例之间分配请求,从而实现负载均衡,提高系统的性能和可用性。

Ribbon 作为一个客户端负载均衡器,直接在客户端对请求进行分发和管理,而不是通过中间的负载均衡器服务器。

Ribbon 的优点

  1. 客户端负载均衡

    Ribbon 通过在客户端进行负载均衡,减少了服务请求的中间层,提高了系统的性能和响应速度。

  2. 与服务发现的集成

    Ribbon 可以与 Netflix 的 Eureka 服务发现机制无缝集成,从而动态获取服务实例列表,并根据一定的策略进行负载均衡。

  3. 多种负载均衡策略

    Ribbon 提供了多种负载均衡策略,如轮询(Round Robin)、随机(Random)、加权响应时间(Weighted Response Time)等,开发人员可以根据需求选择合适的策略。

  4. 自定义负载均衡规则

    Ribbon 允许开发人员自定义负载均衡规则,以满足特定的业务需求。

  5. 熔断和重试机制

    Ribbon 支持熔断和重试机制,可以在服务调用失败时自动进行重试,提高系统的鲁棒性和稳定性。


Ribbon 示例

import com.netflix.loadbalancer.*;
import com.netflix.client.config.IClientConfig;
import com.netflix.client.config.DefaultClientConfigImpl;
import com.netflix.niws.client.http.RestClient;
import com.netflix.niws.client.http.HttpClientRequest;
import com.netflix.niws.client.http.HttpClientResponse;public class RibbonExample {public static void main(String[] args) throws Exception {IClientConfig config = DefaultClientConfigImpl.getClientConfigWithDefaultValues();RestClient client = (RestClient) ClientFactory.getNamedClient("myClient");// 配置负载均衡规则,这里使用轮询策略IRule loadBalancerRule = new RoundRobinRule();client.setLoadBalancerRule(loadBalancerRule);// 发起请求HttpClientRequest request = HttpClientRequest.newBuilder().setUri(new URI("http://my-service/endpoint")).build();HttpClientResponse response = client.executeWithLoadBalancer(request);System.out.println("Response: " + response.getEntity(String.class));}
}

Netflix Feign 和 Ribbon整合

Netflix Feign 和 Ribbon 都是 Netflix 开源的软件组件,常用于构建微服务架构中的服务调用和负载均衡。

虽然它们各自有不同的功能,但它们可以无缝集成,以提供更强大的服务调用和负载均衡解决方案。

下面详细说明 Feign 和 Ribbon 的关系及其结合使用的优势。

Feign 与 Ribbon 的关系
  1. 集成使用

    Feign 可以与 Ribbon 集成使用,以实现客户端负载均衡。当使用 Feign 时,默认情况下会启用 Ribbon 作为负载均衡器。这意味着每次 Feign 调用服务时,Ribbon 会自动在可用的服务实例之间分配请求,从而实现负载均衡。

  2. 简化配置

    通过集成,Feign 可以简化客户端负载均衡的配置。开发人员只需配置 Feign 客户端,Ribbon 就会自动处理负载均衡逻辑,无需手动编写复杂的负载均衡代码。

  3. 服务发现集成

    当与 Eureka 服务发现结合使用时,Feign 和 Ribbon 可以动态地发现和调用服务实例。Eureka 提供服务实例列表,Ribbon 进行负载均衡,而 Feign 则简化了服务调用的代码编写。

Feign 与 Ribbon 结合使用的示例

以下是一个使用 Spring Cloud、Feign 和 Ribbon 的简单示例:

// 服务接口定义
@FeignClient(name = "my-service")
public interface MyServiceClient {@GetMapping("/endpoint")String getEndpointData();
}// Spring Boot 应用
@SpringBootApplication
@EnableFeignClients
public class FeignRibbonExampleApplication {public static void main(String[] args) {SpringApplication.run(FeignRibbonExampleApplication.class, args);}
}// 使用 Feign 调用服务
@RestController
public class MyController {@Autowiredprivate MyServiceClient myServiceClient;@GetMapping("/call")public String callService() {return myServiceClient.getEndpointData();}
}
配置文件(application.yml)
spring:application:name: feign-ribbon-examplecloud:loadbalancer:ribbon:enabled: true# Ribbon 负载均衡配置
my-service:ribbon:listOfServers: http://localhost:8081,http://localhost:8082
说明:
  1. Feign 客户端定义

    使用 @FeignClient 注解定义一个 Feign 客户端接口 MyServiceClient,指定要调用的服务名称 my-service

  2. Spring Boot 应用

    在 Spring Boot 应用中启用 Feign 客户端支持,使用 @EnableFeignClients 注解。

  3. 调用服务

    在控制器中,通过自动注入的方式使用 Feign 客户端 myServiceClient 来调用服务端点。

  4. 配置文件

    在配置文件中,指定 Ribbon 的负载均衡配置,定义服务实例的列表。

通过这种方式,Feign 和 Ribbon 的集成使得服务调用变得非常简单,并且自动实现了负载均衡。开发人员只需关注业务逻辑,而不需要担心底层的负载均衡和服务发现细节。


Feign 与 Ribbon 结合使用的应用场景

Feign 和 Ribbon 的结合使用在微服务架构中非常常见,特别是在需要实现客户端负载均衡和服务调用的场景中。以下是一些典型的应用场景:

1. 动态服务发现与调用

在微服务架构中,服务实例可能动态变化,例如服务实例的上线、下线或扩容。使用 Feign 和 Ribbon 结合,可以实现动态的服务发现和调用。Feign 简化了服务调用的代码,而 Ribbon 负责在多个服务实例之间进行负载均衡。

应用场景:例如,一个订单服务需要调用库存服务来检查库存情况,库存服务的实例可能在不同的服务器上运行。使用 Feign 和 Ribbon,订单服务可以动态发现和调用库存服务实例。

2. 负载均衡

当一个服务有多个实例时,负载均衡可以确保请求均匀分布到不同的实例上,从而提高系统的整体性能和可靠性。Ribbon 提供了多种负载均衡策略,如轮询、随机、加权等,可以根据具体需求进行选择。

应用场景:例如,一个用户服务有多个实例运行在不同的节点上,通过 Feign 和 Ribbon,客户端请求可以均匀分布到这些实例上,避免某个实例过载。

3. 服务熔断与重试

结合使用 Feign、Ribbon 和 Hystrix,可以实现服务熔断和重试机制。当某个服务实例不可用时,Hystrix 可以快速失败,避免影响其他服务,同时 Ribbon 可以选择其他可用的服务实例进行重试。

应用场景:例如,一个支付服务需要调用外部支付网关,外部支付网关可能会偶尔不可用。使用 Feign、Ribbon 和 Hystrix,可以在支付网关不可用时快速失败,并重试其他可用的网关实例。

4. 服务降级

在高并发场景下,如果某个服务不可用或响应过慢,可以进行服务降级,提供备用方案,保证系统的可用性。结合 Hystrix,可以实现服务降级功能。

应用场景:例如,在电商网站中,如果商品详情服务不可用,可以提供一个默认的商品信息,避免影响用户的购物体验。


总结

Netflix Feign 通过其简洁的声明式语法和强大的集成功能,使微服务之间的通信变得更加简单和高效。

它不仅减少了开发人员的工作量,还提高了代码的可维护性和可读性。

通过与其他 Netflix 组件和 Spring Cloud 的无缝集成,Feign 成为构建现代微服务架构中不可或缺的一部分。

希望通过本篇文章的介绍和示例,您能够更好地理解并应用 Feign,在您的微服务项目中实现更加高效的服务调


强烈推荐

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站:人工智能

b004071ozy_05_amzn


专栏集锦

大佬们可以收藏以备不时之需:

Spring Boot 专栏:http://t.csdnimg.cn/peKde

ChatGPT 专栏:http://t.csdnimg.cn/cU0na

Java 专栏:http://t.csdnimg.cn/YUz5e

Go 专栏:http://t.csdnimg.cn/Jfryo

Netty 专栏:http://t.csdnimg.cn/0Mp1H

Redis 专栏:http://t.csdnimg.cn/JuTue

Mysql 专栏:http://t.csdnimg.cn/p1zU9

架构之路 专栏:http://t.csdnimg.cn/bXAPS


写在最后

感谢您的支持和鼓励! 😊🙏

如果大家对相关文章感兴趣,可以关注公众号"架构殿堂",会持续更新AIGC,java基础面试题, netty, spring boot, spring cloud等系列文章,一系列干货随时送达!

如果有项目或者毕设合作,请联系下面微信名片

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

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

相关文章

OpenStack开源虚拟化平台(二)

目录 三、对象存储服务Swift&#xff08;一&#xff09;Swift特性&#xff08;二&#xff09;应用场景&#xff08;三&#xff09;Swift主要组件&#xff08;四&#xff09;Swift基本原理&#xff08;五&#xff09;实例分析 四、镜像服务Glance&#xff08;一&#xff09;Glan…

STM32自己从零开始实操08:电机电路原理图

一、LC滤波电路 其实以下的滤波都可以叫低通滤波器。 1.1倒 “L” 型 LC 滤波电路 1.1.1定性分析 1.1.2仿真实验 电感&#xff1a;通低频阻高频的。仿真中高频信号通过电感&#xff0c;因为电感会阻止电流发生变化&#xff0c;故说阻止高频信号 电容&#xff1a;隔直通交。…

华为云服务器系统重装

文章目录 1 登录云服务器&#xff0c;点击控制台2 选择实例3 点击更多&#xff0c;选择重装系统4 勾选关机&#xff0c;填写密码&#xff0c;点击确定5 选择自己方便的认证方式6 同意协议7 等待完成8 重装完毕 1 登录云服务器&#xff0c;点击控制台 2 选择实例 3 点击更多&…

C语⾔数据类型和变量

C语⾔数据类型和变量 1.数据类型介绍1.1 字符型1.2 整型1.3 浮点型1.4 布尔类型1.5 各种数据类型的长度1.5.1 sizeof操作符1.5.2 数据类型长度1.5.3 sizeof中表达式不计算 2. signed 和 unsigned3. 数据类型的取值范围4. 变量4.1 变量的创建4.2 变量的分类 5. 算术操作符&#…

[每周一更]-(第103期):GIT初始化子模块

文章目录 初始化和更新所有子模块分步骤操作1. 克隆包含子模块的仓库2. 初始化子模块3. 更新子模块 查看子模块状态提交子模块的更改处理子模块路径错误的问题 该问题的缘由是因为&#xff1a;在写某些代码的时候&#xff0c;仓库中有些文件夹&#xff0c;只提交了文件夹名称到…

缓存双写一致性(笔记)

缓存更新方案 旁路缓存模式 这是比较多的 旁路缓存模式&#xff1a;缓存有就返回&#xff0c;没有数据库查询&#xff0c;放入缓存返回。 还有些常用缓存策略 读穿透模式 读穿透和旁路很相似&#xff0c;程序不需要关注从哪里读取数据&#xff0c;它只需要从缓存查询数据。…

海思SS928/SD3403开发笔记4——u盘挂载

首先一定要将u盘格式化成fat32。 挂载 mkdir /mnt/usb mount /dev/sda1 /mnt/usb成功示意图&#xff1a; 取消挂载 umount /mnt/usb

学习笔记——动态路由——OSPF(OSPF协议的工作原理)

八、OSPF协议的工作原理 1、原理概要 (1)相邻路由器之间周期性发送HELLO报文&#xff0c;以便建立和维护邻居关系 (2)建立邻居关系后&#xff0c;给邻居路由器发送数据库描述报文(DBD)&#xff0c;也就是将自己链路状态数据库中的所有链路状态项目的摘要信息发送给邻居路由器…

vite+vue集成cesium

1、创建项目、选择框架vuejs pnpm create vite demo_cesium 2、进入项目安装依赖 cd demo_cesium pnpm install3、安装cesium及插件 3、pnpm i cesium vite-plugin-cesium 4、修改vite-config.js import { defineConfig } from vite import vue from vitejs/plugin-vue impo…

怎么测试远程服务器能否连通

远程服务器连接测试的方法很多&#xff0c;下面简单介绍下其中两种方法。 ping命令 按WINR快截键&#xff0c;打开“运行”对话框&#xff0c;输入cmd&#xff0c;回车&#xff0c;打开命令提示符。 输入ping IP地址或ping 域名即可&#xff0c;如ping360服务器通不通&#xf…

第十四届蓝桥杯省赛C++B组D题【飞机降落】题解(AC)

解题思路 这道题目要求我们判断给定的飞机是否都能在它们的油料耗尽之前降落。为了寻找是否存在合法的降落序列&#xff0c;我们可以使用深度优先搜索&#xff08;DFS&#xff09;的方法&#xff0c;尝试所有可能的降落顺序。 首先&#xff0c;我们需要理解题目中的条件。每架…

【OceanBase】OBProxy 无状态的理解

SueWakeup 个人主页&#xff1a;SueWakeup 系列专栏&#xff1a;为祖国的科技进步添砖Java 个性签名&#xff1a;保留赤子之心也许是种幸运吧 本文封面由 凯楠&#x1f4f8;友情提供 目录 前言 OBProxy 无状态的概述 OBProxy 无状态特性带来的优点 1. 高可用 2. 负载均衡…

盛元广通打造智慧校园实验室安全管理系统

盛元广通智慧校园实验室安全管理系统以安全为重点&#xff0c;构建由学校、二级单位、实验室组成的三级联动的实验室安全多级管理体系、多类用户角色&#xff0c;内置教育部标准检查表&#xff0c;支撑实验室相关业务过程的智慧管理。实现通过PC端/手机移动端开展检查工作、手机…

基于贵州非遗推广小程序的设计与实现14362

基于贵州非遗推广小程序的设计与实现 摘 要 本文设计并实现了一个基于贵州非遗推广的小程序&#xff0c;旨在通过小程序平台推广和展示贵州省非物质文化遗产。该小程序提供了非遗项目介绍、相关活动展示、购买非遗产品等功能。 首先&#xff0c;我们收集了贵州省各个非遗项目的…

惠海 H6912 升压恒流芯片IC 支持2.6-40V升12V24V36V48V60V100V 10A 摄影灯 太阳能灯 UV灯 杀菌灯

1.产品描述 H6912是一款外围电路简洁的宽调光比升压调光LED恒流驱动器&#xff0c;可适用于2.6-40V输入 电压范围的LED恒流照明领域。H6912可以实现高精度的恒流效果&#xff0c;输出电流恒流精度≤士3%&#xff0c;电压工作范围为2.6-40V.可以轻松满足锂电池及中低压的应用需…

【Python】Python环境搭建教学#保姆级教学#手把手带你安装——内附Python环境搭建安装包(Python、PyCharm(社区版)安装包)

Python环境搭建 导读一、初识Python1.1 Python的由来1.2 Python的用途1.3 Python的优缺点1.4 Python的前景&#xff08;钱景&#xff09; 二、Python环境搭建2.1 运行环境——Python安装2.2 开发环境——PyCharm安装2.3 项目创建2.4 基本配置2.4.1 主题配置2.4.2 背景图设置2.4…

2024 年江西省研究生数学建模竞赛A题:交通信号灯管理问题分析、实现代码及参考论文

2024 年江西省研究生数学建模竞赛题目交通信号灯管理 1 题目 交通信号灯是指挥车辆通行的重要标志&#xff0c;由红灯、绿灯、 黄灯组成。红灯停、绿灯行&#xff0c;而黄灯则起到警示作用。交通 信号灯分为机动车信号灯、非机动车信号灯、人行横道信号 灯、方向指示灯等。 一…

实体零售连锁企业如何通过物流接口实现数智化转型升级?

在电子商务浪潮的持续冲击下&#xff0c;传统的实体零售行业面临着巨大的挑战。为了在线上线下融合的新零售时代保持竞争力&#xff0c;众多实体零售企业积极寻求数字化转型的突破。 某中国零售连锁百强企业近年来致力于打造自有品牌的线上销售体系&#xff0c;自2021年8月起接…

MySQL:数据类型

数据类型 1. 字符串类型2. 整数类型3. 定点数类型和浮点数类型4. 布尔类型5. 枚举和集合类型6. 日期和时间类型7. Blob类型8. JSON类型 字符串类型、数字类型、日期和时间类型、存放二进制的数据类型、存放地理数据的类型。 1. 字符串类型 字符串类型也可以用来存储邮编&…

Windows server 由于没有远程桌面授权服务器可以提供许可证,远程会话连接已断开。

问题现象&#xff1a; 解决办法 临时远程方式1: 打开 mstsc 时带上 /admin 等参数&#xff0c;如下图所示&#xff1a; 使用“mstsc /admin /v:目标ip”来强制登录服务器&#xff0c;但只能是管理员身份。 远程方式2&#xff1a; 通过VM远程登陆系统后&#xff0c;运行输入R…