微服務項目遠程調用時的負載均衡是如何實現的?

負載均衡概述

負載均衡是微服務架構中的核心組件,用于將請求合理分配到多個服務實例上,提高系統的可用性和性能。


負載均衡的分類

負載均衡大致可以分為兩類

1. 服務端負載均衡

  • 實現位置:獨立部署的負載均衡服務器(位于客戶端和服務端之間)
  • 工作原理:客戶端請求先到達負載均衡器,由負載均衡器選擇具體的服務實例
  • 代表產品:Nginx、HAProxy、F5、阿里云SLB
  • 優點:集中管理、配置簡單
  • 缺點:增加網絡延遲、單點故障風險
客戶端
負載均衡器
Nginx/HAProxy/F5
服務實例1
192.168.1.10:8080
服務實例2
192.168.1.11:8080
服務實例3
192.168.1.12:8080

2. 客戶端負載均衡

  • 實現位置:集成在客戶端應用程序內部
  • 工作原理:客戶端維護服務提供者列表,根據算法選擇服務實例
  • 代表產品:Ribbon、Spring Cloud LoadBalancer
  • 優點:無單點故障、減少網絡跳轉
  • 缺點:客戶端復雜度增加
獲取服務列表
服務注冊
服務注冊
服務注冊
客戶端應用
內置負載均衡組件
Ribbon/LoadBalancer
注冊中心
Eureka/Nacos
服務實例1
payment-service:8001
服務實例2
payment-service:8002
服務實例3
payment-service:8003

Spring Cloud中的負載均衡實現

1. Feign + Ribbon(Spring Cloud 2020之前)

// 依賴配置
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>// 主啟動類
@SpringBootApplication
@EnableFeignClients
public class OrderApplication {public static void main(String[] args) {SpringApplication.run(OrderApplication.class, args);}
}// Feign客戶端定義
@FeignClient(name = "payment-service")
public interface PaymentService {@GetMapping("/payment/get/{id}")String getPaymentById(@PathVariable("id") Long id);
}

工作原理

  1. Feign接收到對服務名(“payment-service”)的調用請求
  2. Ribbon的LoadBalancerFeignClient通過攔截器機制自動攔截HTTP請求,識別服務名
  3. Ribbon從服務注冊中心獲取該服務(“payment-service”)的可用實例列表
  4. 使用默認的輪詢算法或配置的其他算法選擇目標實例
  5. 將HTTP請求路由到選中的服務實例并返回結果

2. Feign + Spring Cloud LoadBalancer(Spring Cloud 2020之后)

// 依賴配置
<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>// 主啟動類
@SpringBootApplication
@EnableFeignClients
public class OrderApplication {public static void main(String[] args) {SpringApplication.run(OrderApplication.class, args);}
}// Feign客戶端定義
@FeignClient(name = "payment-service")
public interface PaymentService {@GetMapping("/payment/get/{id}")String getPaymentById(@PathVariable("id") Long id);
}

工作原理

  1. Feign接收到對服務名(“payment-service”)的調用請求
  2. Spring Cloud LoadBalancer的LoadBalancerInterceptor通過攔截器機制自動攔截HTTP請求,提取服務名
  3. Spring Cloud LoadBalancer從服務注冊中心獲取該服務(“payment-service”)的可用實例列表
  4. 使用輪詢算法或配置的其他算法選擇目標實例
  5. 將HTTP請求路由到選中的服務實例并返回結果

3. Feign + 自定義負載均衡策略

// 依賴配置
<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>// 主啟動類
@SpringBootApplication
@EnableFeignClients
public class OrderApplication {public static void main(String[] args) {SpringApplication.run(OrderApplication.class, args);}
}// 自定義負載均衡配置
@Configuration
public class CustomLoadBalancerConfig {@Beanpublic ReactorLoadBalancer<ServiceInstance> randomLoadBalancer(Environment environment,LoadBalancerClientFactory clientFactory) {String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);return new RandomLoadBalancer(clientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class), name);}
}// Feign客戶端定義
@FeignClient(name = "payment-service", configuration = CustomLoadBalancerConfig.class)
public interface PaymentService {@GetMapping("/payment/get/{id}")String getPaymentById(@PathVariable("id") Long id);
}

工作原理

  1. Feign接收到對服務名(“payment-service”)的調用請求
  2. Spring Cloud LoadBalancer的LoadBalancerInterceptor通過攔截器機制自動攔截HTTP請求,并提取服務名
  3. 自定義LoadBalancer從服務注冊中心獲取該服務(“payment-service”)的可用實例列表
  4. 使用自定義負載均衡策略選擇目標實例
  5. 將HTTP請求路由到選中的服務實例并返回結果

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/88411.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/88411.shtml
英文地址,請注明出處:http://en.pswp.cn/web/88411.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【中文核心期刊推薦】中國農業科技導報

《中國農業科技導報》是中國科技核心期刊&#xff0c;也是北京大學圖書館“中文核心期刊要目總覽”收錄的期刊。它是由中國農村技術開發中心主辦&#xff0c;全面為科教興農服務的綜合性農業學術期刊。&#xfeff;《中國農業科技導報》是中國農業科學院生物技術研究所承辦的&a…

php 如何通過mysqli操作數據庫?

在PHP中&#xff0c;mysqli&#xff08;MySQL Improved Extension&#xff09;是操作MySQL數據庫的擴展庫&#xff0c;提供了面向對象和過程式兩種風格。以下是mysqli的基本操作方法&#xff1a; 1. 連接數據庫 面向對象風格 $mysqli new mysqli(localhost, username, passwor…

c/c++拷貝函數

memcpy()函數概要原型void * memcpy ( void * dest, const void * src, size_t num );功能memcpy()會復制 src 所指的內存內容的前 num 個字節到 dest所指的內存地址上&#xff08;memcpy()并不關心被復制的數據類型&#xff0c;只是逐字節地進行復制&#xff0c;這給函數的使用…

HTTP核心基礎詳解(附實戰要點)

目錄 一圖勝千言&#xff1a;HTTP核心機制圖解?編輯 一、HTTP本質&#xff1a;通信的橋梁 二、五大核心特性解析 三、HTTP頭部&#xff1a;隱藏的控制中心 四、連接管理&#xff1a;性能關鍵點 開發者必知實踐技巧 一圖勝千言&#xff1a;HTTP核心機制圖解 一、HTTP本質…

華為靜態路由配置

問題描述&#xff1a;針對兩臺筆記本和兩個路由器在不同的網段場景中&#xff0c;對兩個路由器進行靜態路由配置。下面以如下場景為例&#xff0c;介紹詳細配置過程。配置步驟&#xff1a; 1、對每個路由器的接口下配置IP地址 [huawei]interface gx/x/x [huawei-interface]ip a…

閑庭信步使用圖像驗證平臺加速FPGA的開發:第八課——圖像數據的行緩存

&#xff08;本系列只需要modelsim即可完成數字圖像的處理&#xff0c;每個工程都搭建了全自動化的仿真環境&#xff0c;只需要雙擊文件就可以完成整個的仿真&#xff0c;大大降低了初學者的門檻&#xff01;&#xff01;&#xff01;&#xff01;如需要該系列的工程文件請關注…

經典排序算法

文章目錄前言1. 排序的基本概念1.1 排序是什么&#xff1f;1.2 常見的排序算法概覽2. 常見排序算法的實現2.1 插入排序 (Insertion Sort)2.1.1 基本思想2.1.2 直接插入排序2.1.3 希爾排序 (Shell Sort)2.2 選擇排序 (Selection Sort)2.2.1 直接選擇排序2.2.2 堆排序 (Heap Sort…

RabbitMQ 消息隊列:從入門到Spring Boot實戰

RabbitMQ 作為一款開源的、基于 AMQP&#xff08;Advanced Message Queuing Protocol&#xff09;協議實現的消息代理&#xff0c;憑借其強大的功能、靈活的路由機制以及出色的性能&#xff0c;在業界得到了廣泛的應用。無論是處理高并發訂單、異步通知、日志收集還是系統解耦&…

代賬行業數字化破局:從“知道”到“做到”,三步走穩贏!

認知&#xff01;降本&#xff01;增收&#xff01;數字化&#xff01;——這不僅是口號&#xff0c;更是代賬行業在激烈競爭和時代變化中生存發展的關鍵。很多代賬同行其實都明白趨勢&#xff0c;也知道大概該怎么做。但問題卡在第一步&#xff1a;不知道怎么開始&#xff0c;…

Mac 電腦crontab執行定時任務【Python 實戰】

1、crontab -e 編輯定時任務列表 crontab -e查看當前定時任務列表,長按 i 編輯,編輯完之后按 esc 退出編輯,然后輸入:wq 保存并提出。 如下: (base) charles@zl ~ % crontab -e58 15 * * * /Library/Frameworks/Python.framework/Versions/3.8/bin/python3 /Users/charle…

go go go 出發咯 - go web開發入門系列(三) 項目基礎框架搭建與解讀

go go go 出發咯 - go web開發入門系列&#xff08;三&#xff09; 項目基礎框架搭建與解讀 往期回顧 go go go 出發咯 - go web開發入門系列&#xff08;一&#xff09; helloworldgo go go 出發咯 - go web開發入門系列&#xff08;二&#xff09; Gin 框架實戰指南 前言 如…

【字節跳動】數據挖掘面試題0014:SQL中count(1), count(*), count(列)區別

文章大綱SQL 中 count(1)、count(*)、count(某列) 的區別一、核心定義與行為差異二、示例說明差異三、性能差異與優化四、適用場景建議五、面試應答要點六、索引掃描與全表掃描1. 索引掃描的觸發條件2. 全表掃描的適用場景3. 常見面試問題點Q1&#xff1a;索引掃描一定比全表掃…

Linux面試問題-軟件測試

1、你在上一家公司常用的Linux命令有哪些&#xff1f;答&#xff1a;使用vim/vi編輯文件&#xff0c;使用cat&#xff0c;more,less&#xff0c;head查看文件&#xff0c;使用grep過濾日志中的error,使用ps查看進程&#xff0c;使用top查看實時進程&#xff0c;netstat查看端口…

時序數據庫的存儲之道:從數據特性看技術要點

時序數據的獨特挑戰時序數據(Time-Series Data)是指按時間順序記錄的一系列數據點&#xff0c;在物聯網、金融、工業監控等領域無處不在。與傳統數據相比&#xff0c;時序數據具有幾個鮮明特點&#xff1a;時間導向性&#xff1a;每個數據點都帶有精確的時間戳高寫入量&#xf…

【vim中替換】

vim中替換1 : s/在Vim中經常高頻使用到的命令&#xff1a;1 : s/ &#xff1a;s 命令的基本語法是 :[range]s/{pattern}/{string}/[flags]&#xff0c;其中&#xff1a; ? [range] 是可選的范圍&#xff0c;用于指定替換的行范圍。例如&#xff0c;% 表示全文&#xff0c;10,…

Qt實戰:使用QSqlDatabase連接MySQL,并實現增刪改查

文章目錄一、創建數據表二、連接MySQL數據庫三、封裝成一個完整的輕量級 ORM 風格類四、實現派生具體模型類五、支持多線程連接池 ORM 事務封裝一、創建數據表 數據庫名&#xff1a; 我們先創建一個數據庫&#xff0c;名字叫 game_db&#xff1a; CREATE DATABASE IF NOT E…

Python腳本保護工具庫之pyarmor使用詳解

概要 PyArmor是一個專門為Python代碼提供加密保護的第三方庫,旨在解決Python源代碼易被反編譯和泄露的安全問題。作為一種動態代碼保護工具,PyArmor能夠對Python腳本進行混淆和加密處理,有效防止源代碼被惡意獲取、分析或篡改。該庫特別適用于商業軟件開發、知識產權保護和…

倉頡編程語言:從入門到精通

為啥要瞅瞅倉頡這玩意兒&#xff1f; 有一說一&#xff0c;現在的編程語言多得跟米一樣&#xff0c;對吧&#xff1f;那一門新語言想火&#xff0c;沒點絕活兒肯定不行。倉頡&#xff08;Cangjie&#xff09;這哥們兒&#xff0c;是華為搞出來的新玩意兒&#xff0c;靜態編譯的…

線性探針是什么:是一種用于探測神經網絡中特定特征的工具

線性探針是什么 線性探針是一種在機器學習和相關領域廣泛應用的技術,用于評估預訓練模型特征、檢測數據中的特定序列等。在不同的應用場景下,線性探針有著不同的實現方式和作用: 評估預訓練模型特征:在機器學習中,線性探針是一種評估預訓練模型“特征遷移能力”的標準化方…

【論文閱讀】Few-Shot PPG Signal Generation via Guided Diffusion Models

從少量樣本數據選擇到后處理的整體框架。首先,擴散模型在N樣本數據集和指導下的訓練。接著,模型生成一個增強的數據集,并進一步優化以提高保真度。最后,這些合成數據與少量樣本訓練數據集結合,用于基準模型的訓練和評估。數據分布從最初的紅色變為保真度增強的藍色,這表明…