Neutorn LBaaS 原理

Load Balance as a Service(LBaaS)是 Neutron 提供的一項高級網絡服務。
LBaaS 允許租戶在自己的網絡中創建和管理 load balancer。

load balancer 可以說是分布式系統中比較基礎的組件。
它接收前端發來的請求,然后將請求按照某種均衡策略轉發給后端資源池中的某個處理單元,以完成處理。
load balancer 可以實現系統高可用和橫向擴展。

LBaaS 有三個主要的概念: Pool Member,Pool 和 Virtual IP

Pool Member
Pool Member 是 layer 4 的實體,擁有 IP 地址并通過監聽端口對外提供服務。 例如 Pool Member 可以是一個 web server,IP 為 172.16.100.9 并通過 80 端口提供 HTTP 服務。

Pool
Pool 由一組 Pool Member 組成。 這些 Pool Member 通常提供同一類服務。 例如一個 web server pool,包含: web1:172.16.100.9:80 web2:172.16.100.10:80

Virtual IP
Virtual IP 也稱作 VIP,是定義在 load balancer 上的 IP 地址。 每個 pool member 都有自己的 IP,但對外服務則是通過 VIP。

load balancer 負責監聽外部的連接,并將連接分發到 pool member。 外部 client 只知道 VIP,不知道也不需要關心是否有 pool 或者有多少個 pool member。

OpenStack Neutron 目前默認通過 HAProxy 軟件來實現 LBaaS。 HAProxy 是一個流行的開源 load balancer。 Neutron 也支持其他一些第三方 load balancer。

下圖展示了 HAProxy 實現 load balancer 的方式。

左圖是 client 發送請求到 web server 的數據流:
1. Client 10.10.10.4 通過瀏覽器訪問服務器的外網 IP 10.10.10.7。

2. 請求首先到達路由器,將目的地址設置為服務器的內網 VIP 172.16.100.11

3. VIP 設置在 load balancer 上,load balancer 收到請求后選擇 pool member WEB1,
將數據包的目的 IP 設為 WEB1 的地址 172.16.100.9。

4. 在將數據包轉發給 WEB1 之前,load balancer 將數據包的源 IP 修改為自己的 VIP 地址 172.16.100.11,
其目的是保證 WEB1 能夠將應答數據發送回 load balancer。

5. WEB1 收到請求數據包。

右圖是 web server 應答的數據流:

1. WEB1 將數據包發送給 load balancer。

2. load balancer 收到 WEB1 發回的數據后,將目的 IP 修改為 Client 的地址 10.10.10.4。 同時也將數據包的源 IP 修改為 VIP 地址 172.16.100.11,保證 Client 能夠將后續的數據發送給自己。

3. load balancer 將數據發送給路由器。

4. 路由器將數據包的源地址恢復成服務器的外網 IP 10.10.10.7,然后發送給 Client。

5. Client 收到應答數據。

?

?

haproxy配置信息存放在/var/lib/neutron/lbaas/

?

轉載于:https://www.cnblogs.com/wangjq19920210/p/9187250.html

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

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

相關文章

判斷一個圖中有無環路的存在

這里要引入兩個概念: 1.樹邊:是一條未被遍歷過的邊,它指向一個未被訪問過的點。 2.反向邊:是一條未被遍歷過的邊,它指向一個被訪問過的點。 如果圖中有環路的存在,那么環路的最后一個邊必然是一條反向邊。 …

精選的一些《編程之美》相關資料

又要到一年的招聘季了,肯定又有很多人開始啃《編程之美》了吧。這本書從開闊視野的角度來說很好,不過限于篇幅,有的問題并沒有講清楚(甚至問題敘述模棱兩可、被標榜為“鼓勵同面試官交流以獲得更多細節”);…

java 內置函數_java8 四大內置核心函數式接口

其他補充接口:一、Consumer:消費型接口(void accept(T t))來看一個簡單得例子:1 /**2 * 消費型接口Consumer3 */4 Test5 public void test1 () {6 consumo(500, (x) -> System.out.println(x));7 }89 public void consumo (double money, …

jQuery - (JQuery datatables api 使用解讀)

學習可參考&#xff1a;http://www.guoxk.com/node/jquery-datatables http://yuemeiqing2008-163-com.iteye.com/blog/2006942 分別導入css和js文件 <link href"~/Content/bootstrap.css" rel"stylesheet" /> <link href"~/Content/datatab…

Tomcat配置JNDI數據源

經過3個多小時的努力&#xff0c;配置JNDI數據源(主要是通過DBCP連接池)終于搞定&#xff5e;還是Tomcat官方的說明好&#xff0c;不過全是英文的&#xff0c;大概還看得懂&#xff0e;百度上那么花花綠綠的太多了&#xff0c;一個也沒成功&#xff01;&#xff0e;&#xff0e…

java 線程池 固定大小_使用Executors服務在Java中創建固定大小線程池的最佳方法...

查看源代碼,您將意識到&#xff1a;Executors.newFixedThreadPool(threadPoolSize);相當于&#xff1a;return new ThreadPoolExecutor(threadPoolSize, threadPoolSize, 0L, MILLISECONDS,new LinkedBlockingQueue());由于它不提供顯式的RejectedExecutionHandler,因此使用默認…

令牌驗證 token

通過令牌驗證在注冊中心控制權限&#xff0c;以決定要不要下發令牌給消費者&#xff0c;可以防止消費者繞過注冊中心訪問提供者&#xff0c;另外通過注冊中心可靈活改變授權方式&#xff0c;而不需修改或升級提供者。 可以全局設置開啟令牌驗證&#xff1a; <!--隨機token令…

easybcd 支持 windows 10 和 ubuntu 14.04 雙系統啟動

家里計算機系統 windows 10 全新安裝。 原本是雙系統的&#xff0c;還有一個ubuntu。 windows 10 安裝以后&#xff0c;恢復ubuntu就是問題了。 (事后經驗&#xff1a;請不要立刻安裝bcd修改工具) 最初的方法是利用easybcd修改bcd記錄。操作是成功的&#xff0c;但系統重新啟動…

需求分析與原型設計

結對者&#xff1a;031402140李嚴 0314026617林瑞斌 需求分析與原型設計 NABCD模型 N&#xff08;Need&#xff0c;需求&#xff09;: 收集信息的過程太過繁瑣&#xff0c;有班級總負責人需匯總每一個同學的志愿并填入excel表中&#xff0c;上交年級負責人&#xff0c;年級負責…

java導出表格_java怎么導出excel表格

import com.spire.xls.ExcelVersion;import com.spire.xls.Workbook;import com.spire.xls.Worksheet;public class InsertArray {public static void main(String[] args) {//創建Workbook對象Workbook wb new Workbook();//獲取第一張62616964757a686964616fe4b893e5b19e313…

for 循環 和 Array 數組對象

博客地址&#xff1a;https://ainyi.com/12 for 循環 和 Array 數組對象方法 for for-in for-of forEach效率比較 - 四種循環&#xff0c;遍歷長度為 1000000 的數組疊加&#xff0c;得到的時間差&#xff1a;for 3for-in 250for-of 7forEach 44- 效率速度&#xff1a;for >…

IntelliJ IDEA---java的編譯工具【轉】

轉自&#xff1a;http://baike.baidu.com/link?urlsEpS0rItaB9BiO3i-qCdGSYiTIVPSJfBTjSXXngtN2hBhGl1j36CYQORKrbpqMHqjvu3MOfkgVzpMqr8To2l2q IDEA 全稱 IntelliJ IDEA&#xff0c;是java語言開發的集成環境&#xff0c;IntelliJ在業界被公認為最好的java開發工具之一&#…

OC中文件讀取類(NSFileHandle)介紹和常用使用方法

NSFileHandle 1.NSFileManager類主要對于文件的操作(刪除&#xff0c;修改&#xff0c;移動&#xff0c;賦值等等) //判斷是否有 tagetPath 文件路徑&#xff0c;沒有就創建NSFileManager *fileManage [NSFileManager defaultManager];BOOL success [fileManage createFileAt…

java filereader讀文件_Java FileReader讀文件

import java.io.*;class FileReaderDemo{public static void main(String[] args) throws IOException{//創建一個文件讀取流對象&#xff0c;和指定名稱的文件相關聯。//要保證該文件是已經存在的&#xff0c;如果不存在&#xff0c;會發生異常FileNotFoundExceptionFileReade…

struts2攔截器

struts攔截器 圖&#xff1a; 1、攔截器是什么&#xff1f; 分離關注&#xff1a; 完成一個功能&#xff0c;可以寫在一個類中&#xff0c;然后一個類中4個步驟&#xff0c;實現該類完成。 我們可以將4個步驟寫在4個類中&#xff0c;然后每一個類完成一部分功能&#xff0c;然后…

Springboot-Jpa多數據庫配置-2.0+版本

pom.xml增加: <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId></dependency> 配置表同JdbcTemplate配置. 主數據源: ConfigurationEnableTransactionManagementEna…

Windows虛擬地址轉物理地址(原理+源碼實現,附簡單小工具)

By Lthis 上個月就想寫了&#xff0c;一直沒時間...網上大概搜了一下&#xff0c;原理與操作倒是一大堆&#xff0c;一直沒看到源碼實現&#xff0c;總得有人動手&#xff0c;這回輪到我了。東西寫得很爛&#xff0c;請大牛勿噴。一直覺得靠源碼的方式驅動學習是非常好的一種學…

python裝飾器的使用

借用裝飾器&#xff0c;我們可以批量的對老的函數進行改造或擴展老函數功能&#xff0c;比如需要對函數的接收參數進行過濾&#xff0c;Flash的url路由功能就是使用的這個方式 def dropoushu(): # 這一層函數可以去掉&#xff0c;如果去掉了&#xff0c;則使用checkjiou這種方…

7_文件上傳漏洞

文件上傳漏洞 當文件上傳時&#xff0c;若服務端腳本語言未對上傳的文件進行嚴格驗證和過濾&#xff0c;若惡意用戶上傳惡意的腳本文件時&#xff0c;就有可能控制整個網站甚至是服務器&#xff0c;這就是文件上傳漏洞。 權限 1.網站后臺權限&#xff1a;登陸了后臺&#xff0…

mysql數據庫如何實現分頁查詢_不同數據庫的分頁查詢實現方法總結

分頁查詢是數據庫查詢中經常用到的一項操作&#xff0c;對查詢出來的結果進行分頁查詢可以方便瀏覽。那么Oracle、SQL Server、MySQL是如何實現查詢的呢&#xff1f;本文我們就來介紹這一部分內容。首先我們先看一下SQL Server 數據庫中SQL語句查詢分頁數據的解決方案&#xff…