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

news2024/11/16 5:29:26

文章目录

      • 强烈推荐
      • 引言
      • 优点
      • 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 {

    @Autowired
    private MyServiceClient myServiceClient;

    @GetMapping("/call")
    public String callService() {
        return myServiceClient.getEndpointData();
    }
}
配置文件(application.yml)
spring:
  application:
    name: feign-ribbon-example
  cloud:
    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.coloradmin.cn/o/1885054.html

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

相关文章

Win10系统登录界面两个相同用户名的处理方法

在Windows 10系统中只设置了一个帐户&#xff0c;即本地帐户Administrator&#xff0c;但由于一些应用对帐户的要求&#xff0c;会切换到微软帐户登录&#xff0c;而切换之后&#xff0c;在登录界面就会显示微软帐户的名称&#xff0c;故Windows 10系统在登录界面会显示两个相同…

windows网络进阶之listen参数含义

目录 一、前言 二、listen参数 三、实战案例 1. 使用Sleep函数让线程暂停 2. 案例代码展示 3. 编译生成exe文件 一、前言 一、前言 在Windows网络编程中&#xff0c;在使用TCP时&#xff0c;listen函数它是一个重要的关键的步骤&#xff0c;使得套接字能够接收传…

【C++】使用C++在线程中动态记录数据到外部文件

在现代软件开发中&#xff0c;多线程编程已成为处理并发任务、提高程序性能的重要手段。而在多线程环境下&#xff0c;如何有效地管理和记录数据&#xff0c;尤其是将动态生成的数据安全地写入外部文件&#xff0c;是许多应用程序必须面对的问题。本文将深入探讨如何在C中使用多…

FastApi中的常见请求类型

FastApi中的常见请求类型 后端开发语言中&#xff0c;我钟情于node&#xff0c;高效的异步处理真是让我眼前一亮&#xff0c;同时&#xff0c;简单易懂的语法也让我非常倾心 但是但是&#xff0c;因为考虑要写一个深度学习算法的后端接口&#xff0c;所以不得不选用python作为…

传神论文中心|第15期人工智能领域论文推荐

在人工智能领域的快速发展中&#xff0c;我们不断看到令人振奋的技术进步和创新。近期&#xff0c;开放传神&#xff08;OpenCSG&#xff09;社区发现了一些值得关注的成就。传神社区本周也为对AI和大模型感兴趣的读者们提供了一些值得一读的研究工作的简要概述以及它们各自的论…

【linux】虚拟机安装 BCLinux-R8-U4-Server-x86_64

目录 一、概述 1.1移动云Linux系统订阅服务 CLS 1.2 大云天元操作系统BC-Linux 二、安装 一、概述 1.1移动云Linux系统订阅服务 CLS 移动云Linux系统订阅服务 CLS &#xff08;Cloud Linux Service&#xff09;为使用BC-Linux操作系统的用户提供标准维保服务以及高级技术支…

JVM原理(九):JVM虚拟机工具之可视化故障处理工具

1. JHSDB:基于服务性代理的调试工具 JHSDB是一款基于服务性代理实现的进程外调试工具。 服务性代理是HotSpot虚拟机中一组用于映射Java虚拟机运行信息的、主要基于Java语言实现的API集合。 2. JConsole:Java监视与管理控制台 JConsole是一款基于JMX的可视化监视、管理工具。…

矩阵、混剪、大盘,3大功能升级优化!助力企业高效管理!

在数字化转型的浪潮中&#xff0c;企业对于工具与技术的需求愈发强烈。 为满足市场需求&#xff0c;本月【云略】为各企业上线了便捷功能&#xff0c;赋能企业经营决策和业务增长。 矩阵管理 √【矩阵号管理】抖音支持设置城市IP 内容管理 √【混剪任务】支持关联智能发布计…

模拟 ADC 的前端

ADC 的 SPICE 模拟 反复试验的方法将信号发送到 ADC 非常耗时&#xff0c;而且可能有效也可能无效。如果转换器捕获电压信息的关键时刻模拟输入引脚不稳定&#xff0c;则无法获得正确的输出数据。SPICE 模型允许您执行的步是验证所有模拟输入是否稳定&#xff0c;以便没有错误…

百家讲坛 | 裴伟伟:企业中安全团队应当如何反馈漏洞

作者简介&#xff1a;裴伟伟&#xff0c;洞源实验室创始人&#xff0c;国家网安基地网络安全行业专家&#xff0c;网安加社区特聘专家&#xff0c;持有CISSP、PMP证书&#xff0c;曾在HITCON、可信云大会、开源产业大会等安全论坛发表演讲。曾任国内某安全实验室负责人、某互金…

3.js - 色调映射(renderer.toneMapping)

// ts-nocheck// 引入three.js import * as THREE from three// 导入轨道控制器 import { OrbitControls } from three/examples/jsm/controls/OrbitControls// 导入lil.gui import { GUI } from three/examples/jsm/libs/lil-gui.module.min.js// 导入tween import * as TWEEN…

Stable DIffusion 线稿上色+风格迁移教程,建议收藏!

前言 Stable Diffusion 线稿上色与风格迁移教程。 欢迎来到Stable Diffusion的线稿上色与风格迁移教程&#xff01;在这个教程中&#xff0c;我们将引导你如何使用Stable Diffusion技术&#xff0c;将你的线稿作品进行上色&#xff0c;并迁移到不同的艺术风格。让我们开始吧&a…

双端队列广搜——AcWing 175. 电路维修

双端队列广搜 定义 双端队列广搜&#xff08;Breadth-First Search with a Deque&#xff09;是一种图或树的遍历算法变体&#xff0c;它利用了双端队列&#xff08;Deque&#xff0c;全称Double Ended Queue&#xff0c;允许在其两端进行插入和删除操作&#xff09;作为数据…

CentOS7源码安装nginx并编写服务脚本

华子目录 准备下载nginx源码包关闭防火墙关闭selinux安装依赖环境 解压编译安装测试编写服务脚本&#xff0c;通过systemctl实现服务启动与关闭测试 准备 下载nginx源码包 在源码安装前&#xff0c;我们得先下载nginx源码包https://nginx.org/download/这里我下载的是nginx-1…

PHP景区旅游多商户版微信小程序系统源码

解锁景区新玩法&#xff01;​ 引言&#xff1a;一站式旅行新体验 厌倦了传统景区的单调游览&#xff1f;想要一次旅行就能体验多种风情&#xff1f;那么&#xff0c;“景区旅游多商户版”绝对是你的不二之选&#xff01;这个创新模式将景区内多个商户资源整合&#xff0c;为…

Golang-context理解

golang-context笔记整理 golang为何设计context&#xff1f;代码上理解原理空context类cancelCtx类.withcancelctx方法 timerCtx类valueCtx类 golang为何设计context&#xff1f; 有并发特性的语言中&#xff0c;都会有一种说法&#xff1a;创建异步线程或者携程的时候&#x…

【Altium】如何处理PCB上所有焊盘被误盖油

【更多软件使用问题请点击亿道电子官方网站】 1、 文档目标 解决焊盘被误盖油的操作 2、 问题场景 所有焊盘都可以设置为盖油或不盖油&#xff0c;由于焊盘需要用来焊接元器件&#xff0c;所以都不会设置盖油。由于误操作或者创建封装时设置错误&#xff0c;造成一定数量的焊盘…

【GD32】07 - UART串口通信

GD32F407中的UART 今天我用的型号是GD32F407&#xff0c;用其他型号的小伙伴在使用UART的时候注意一下自己手上板子的资源就行&#xff0c;我们使用固件库就算是不同型号其实也是没有什么太大差别的。 我们废话不多说&#xff0c;直接开始讲怎么使用UART。 首先我们先确定串…

【面试干货】Static关键字的用法详解

【面试干货】Static关键字的用法详解 1、Static修饰内部类2、Static修饰方法3、Static修饰变量4、Static修饰代码块5、总结 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 在Java编程语言中&#xff0c;static是一个关键字&#xff0c;它可…

猫头虎博主全栈前沿AI技术领域矩阵社群

猫头虎博主全栈前沿AI技术领域矩阵社群 &#x1f44b;大家好&#xff0c;我是猫头虎&#xff01;今天我要向大家介绍一个非常重要的社群矩阵——专为全栈前沿AI技术领域的朋友们打造的各种技术交流和资源互助的社群。这些社群不仅能帮助大家快速提升技术水平&#xff0c;还能拓…