使用Haproxy搭建Web群集

????????Hapraxy是目前比較流行的一種群集調度工具,同類群集調度工具有很多,如LVS 和Nginx。相 比較而言,LVS.性能最好,但是搭建相對復雜:Nginx的 upstream 模塊支持群集功能,但是對群集節 點健康檢查功能不強,性能沒有Haproxy好。Heproxy官方網站是http://www.haproxy.org/?

索例前置知識點

(1)HTTP請求

????????通過URL訪問網站使用的協議是HTTP協議,此類請求一般稱為HTTP請求。HTTP請求的方式分 為GET方式和 POST方式。當使用瀏覽器訪問某一個URL,會根據請求URL返回狀態碼,通常正常的 狀態碼為2xx.3xx(如200、301),如果出現異常會返回4xx、5xx(如400,500).

????????例如,訪問http://www.test.com/a.php?ld=123,就是一個GET請求,如果訪問正常,會從服 務器的日志中獲取200狀態碼.假如此請求使用POST方式,那么傳遞給a.php的Id參數依舊是123, 但是瀏覽器的URL將不會顯示后面的Id=123字樣,因此表單類或者有用戶名,密碼等內容提交時建 議使用POST方式。不管使用哪種方式,最終a.php獲取的值是一樣的。

(2)負載均衡常用調度算法

????????LVS, Haproxy. Nginx最常用的調度算法有三種,如下所述,

1.RR(Round Robin)。RR算法是最簡單最常用的一種算法,即輪詢調度。例如,有三個節點A、B、C.第一個用戶訪問會被指派到節點A,第二個用戶訪問會被指派到節點B,第三個用戶訪問會 被指派到節點C,第四個用戶訪問繼續指派到節點A,輪詢分配訪問請求實現負載均衡效果。此算 法還有一種加權輪詢,即根據每個節點的權重輪詢分配訪問請求。

2.LC (Least Comections).LC 算法即最小連接數算法,根據后端的節點連接數大小動態分配 前端請求。例如,有三個節點A、B.C,各節點的連接數分別為A:4.B:5.C:6,此時如果有第一 個用戶連接請求,會被指派到A上,連接數變為A:5.B:5.C:6,第二個用戶請求會繼續分配到A 上,連接數變為A:6.B:5.C:6:再有新的請求會分配給B,每次將新的請求指派給連接數最小的 客戶端。由于實際情況下A.B.C的連接數會動態釋放,很難會出現一樣連接數的情況,因此此算 法相比較爪算法有很大改進,是目前用到比較多的一種算法。

3.SH (Source Hashing).SH即基于來源訪問調度算法,此算法用于一些有Session 會話記錄在 服務器端的場景,可以基于來源的P.Cookie 等做群集調度。例如,使用基于源P的群集調度算法, 有三個節點A.B.C.第一個用戶第一次訪問被指派到了A,第二個用戶第一次訪問被指派到了B. 當第一個用戶第二次訪問時會被繼續指派到A.第二個用戶第二次訪問時依舊會被指派到B.只要負 載均衡調度髁不重啟,第一個用戶訪問都會被指派到A.第二個用戶訪問都會被指派到B,實現群集 的調度。此調度算法好處是實現會話保持,但某些尸訪問最非常大時會引起負載不均衡,部分節點 訪問量超大,影響業務使用。

(3)常見的Web群集調度器

????????目前常見的Web群集調度器分為軟件和硬件,軟件通常使用開源的LVS. Haproxy, Nginx,硬件 一般使用比較多的是F5,也有很多人使用國內的一些產品,如梭子魚、綠盟等.

案例環境

? ? ? ? 本案例使用三臺服務器模擬搭建一套Web群集,拓撲圖如下所示:

案例實施

關閉防火墻:systemctl disable firewalld --now

關閉Selinux:setenforce 0

????????????????????????sed -i 's/SELINUX=.*/SELINUX=disabled/g' /etc/selinux/config

配置IP DNS 網關:nmtui

1.編譯安裝Nginx服務器

(1)搭建Nginx1,使用nginx-1.12.0.tar.gz安裝包進行編譯安裝。

[root@Nginx1 ~]# mount /dev/cdrom /mnt/
mount: /dev/sr0 寫保護,將以只讀方式掛載
[root@Nginx1 ~]# yum -y install pcre-devel zlib-devel       //掛載后在本地yum倉庫安裝[root@Nginx1 ~]#useradd -M -s /sbin/nologin nginx   //創建nginx用戶[root@Nginx1 ~]# rz -E  //把源碼包nginx-1.24.0.tar.gz拉進來
rz waiting to receive.[root@Nginx1 ~]# tar zxf nginx-1.24.0.tar.gz  //解壓文件[root@Nginx1 ~]# cd nginx-1.24.0/       //執行編譯安裝
[root@Nginx1 nginx-1.24.0]# ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module
[root@Nginx1 nginx-1.24.0]# make && make install

[root@Nginx1 ~]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/     //創建主程序鏈接文件[root@Nginx1 ~]# echo "<h1>This is nginx Server 192.168.55.49</h1>" > /usr/local/nginx/html/test.html     //建立測試頁面[root@Nginx1 ~]# /usr/local/nginx/sbin/nginx              //啟動Nginx[root@Nginx1 ~]# netstat -anpt | grep nginx
tcp     0     0 0.0.0.0:80            0.0.0.0:*           LISTEN      11121/nginx: master [root@Nginx1 ~]# systemctl stop firewalld.service 

?????????為了方便實驗,網站沒有配置域名,直接使用IP地址。在客戶端訪問http://192.168.55.49/ test.huml測試。

(2)搭建Nginx2.

????????編譯安裝的步驟與Nginx1相同,不同之處在于建立測試頁面。

[root@Nginx2 ~]# echo "<h1>This is nginx Server 192.168.55.50</h1>" > /usr/local/nginx/html/test.html

?2.編譯安裝Haproxy

使用 haproxy-1.5.19.tar.gz安裝包進行編譯安裝

[root@Haproxy ~]# yum -y install pcre-devel bzip2-devel   //組件[root@Haproxy ~]# rz -E
rz waiting to receive.                   //將源碼包haproxy-1.5.19.tar.gz上傳拉進來[root@Haproxy ~]# tar zxf haproxy-1.5.19.tar.gz   
[root@Haproxy ~]# cd haproxy-1.5.19/
[root@Haproxy haproxy-1.5.19]# make TARGET=linux26      //64位系統
[root@Haproxy haproxy-1.5.19]# make install

3.Haproxy服務器配置

(1)建立Haproxy的配置文件。

[root@Haproxy haproxy-1.5.19]# mkdir /etc/haproxy  //創建主配置文件[root@Haproxy haproxy-1.5.19]# cp examples/haproxy.cfg /etc/haproxy/    //將haproxy.cfg文件復制到配置文件目錄

(2)Haproxy配置項介紹。

(3)根據目前的群集設計,將haproxy.cfg配置文件的內容修改如下。

[root@Haproxy ~]# vim /etc/haproxy/haproxy.cfg

4.創建自啟動腳本

[root@Haproxy haproxy-1.5.19]# mkdir /usr/share/haproxy         //創建群集根目錄添加haproxy系統服務:
[root@Haproxy haproxy-1.5.19]# cp examples/haproxy.init /etc/init.d/haproxy    
[root@Haproxy haproxy-1.5.19]# ln -s /usr/local/sbin/haproxy /usr/sbin/haproxy
[root@Haproxy haproxy-1.5.19]# chmod +x /etc/init.d/haproxy
[root@Haproxy haproxy-1.5.19]# chkconfig --add haproxy啟動服務:
[root@Haproxy haproxy-1.5.19]# /etc/init.d/haproxy start
Starting haproxy (via systemctl):                          [  確定  ]啟動服務:
[root@Haproxy haproxy-1.5.19]# systemctl start haproxy關閉防火墻瀏覽器可以進入:
[root@Haproxy haproxy-1.5.19]# systemctl stop firewalld

5.測試Web群集?

????????通過上面的步驟,已經搭建完成Haproxy 的Web群集,接下來需要驗證群集是否工作正常。一 個群集一般需要具備兩個特性,第一個是高性能,第二個是高可用,

(1)測試高性能

在客戶端使用瀏覽器打開http://192.168.55.47/test.html,瀏覽器顯示信息

?

再次打開一個新的瀏覽器頁面訪問http://192.168.55.47/test.html,瀏覽器顯示信息?

?

?

(2)測試高可用

現在將 192.168.55.49的Nginx服務停用,在客戶端使用瀏覽器打開http://192.168.55.47/ test.html,瀏覽器顯示信息

從中可以看出,當一臺節點故障,不會影響群集的使用,這祥就滿足了群集的高可用性。也可 以將192.168.1.62的Nginx服務恢復,再將192.168.1.61的Nginx服務停用,測試高可用性。?

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

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

相關文章

基于YOLOv8/YOLOv7/YOLOv6/YOLOv5的番茄成熟度檢測系統(Python+PySide6界面+訓練代碼)

摘要&#xff1a;開發番茄成熟度檢測系統對于提高農業產量和食品加工效率具有重大意義。本篇博客詳細介紹了如何利用深度學習構建一個番茄成熟度檢測系統&#xff0c;并提供了完整的實現代碼。該系統基于強大的YOLOv8算法&#xff0c;并結合了YOLOv7、YOLOv6、YOLOv5的對比&…

騰訊云幻獸帕魯服務器使用Linux和Windows操作系統,對用戶的技術要求有何不同?

騰訊云幻獸帕魯服務器使用Linux和Windows操作系統對用戶的技術要求有何不同&#xff1f; 首先&#xff0c;從操作界面的角度來看&#xff0c;Windows操作系統相對簡單易操作&#xff0c;適合那些偏好使用圖形化界面操作的用戶。而Linux操作系統則需要通過命令行完成&#xff0…

百度搜索引擎SEO優化方法

隨著互聯網的不斷發展&#xff0c;搜索引擎已經成為人們獲取信息、產品和服務的主要途徑之一。而在中國&#xff0c;百度作為最大的搜索引擎&#xff0c;其影響力不可忽視。了解并掌握百度SEO關鍵詞優化方法&#xff0c;對于提升網站在搜索引擎中的排名至關重要。 關鍵詞選擇&a…

數據結構——跳表

簡單介紹跳表 跳表&#xff08;Skip List&#xff09;是一種可以進行對數級別查找的數據結構&#xff0c;它通過在數據中構建多級索引來提高查詢效率。跳表是一種基于鏈表的隨機化數據結構&#xff0c;其本質是由多個鏈表組成&#xff0c;每個鏈表中的元素都是原始鏈表中的元素…

圖論 - Trie樹(字符串統計、最大異或對)

文章目錄 前言Part 1&#xff1a;Trie字符串統計1.題目描述輸入格式輸出格式數據范圍輸入樣例輸出樣例 2.算法 Part 2&#xff1a;最大異或對1.題目描述輸入格式輸出格式數據范圍輸入樣例輸出樣例 2.算法 前言 本篇博客將介紹Trie樹的常見應用&#xff0c;包括&#xff1a;Trie…

C++ 使用 nlohmann::json存儲json文件

C 使用 nlohmann::json存儲json文件 nlohmann::json 概述JSON 存儲的示例以追加的方式存儲json文件 nlohmann::json 概述 nlohmann::json 是 C 中一個流行的 JSON 庫&#xff0c;由 Niels Lohmann 開發。它提供了一個簡單而強大的 API&#xff0c;用于解析、構建、操作和序列化…

電子電氣架構——車載以太網協議棧

電子電氣架構——車載以太網協議棧 我是穿拖鞋的漢子&#xff0c;魔都中堅持長期主義的汽車電子工程師。 老規矩&#xff0c;分享一段喜歡的文字&#xff0c;避免自己成為高知識低文化的工程師&#xff1a; 沒有人關注你。也無需有人關注你。你必須承認自己的價值&#xff0c…

MySQL入門------數據庫與SQL概述

目錄 前言 一、數據庫相關概念 二、數據模型 1.關系型數據庫&#xff08;RDBMS&#xff09; 三、MySQL數據庫 1.下載和安裝 2.配置環境變量 四、SQL 1.SQL通用語法 2.SQL分類 前言 從本期開始&#xff0c;我們開始學習數據庫的相關理論和實踐知識&#xff0c;從入門…

jupyter 用pyecharts進行數據分析

一、jupyter和pyecharts下載和打開 因為我是用的pycharm&#xff0c;所以我直接在pycharm項目終端中下載pip install jupyter,pip install pyecharts 在你下載的項目路徑中輸入jupyter notebook 之后會進入頁面 Jupyter 具體使用參考這個鏈接&#xff1a;Jupyter Notebook基本…

Pygame教程01:初識pygame游戲模塊

Pygame是一個用于創建基本的2D游戲和圖形應用程序。它提供了一套豐富的工具&#xff0c;讓開發者能夠輕松地創建游戲和其他圖形應用程序。Pygame 支持許多功能&#xff0c;包括圖像和聲音處理、事件處理、碰撞檢測、字體渲染等。 Pygame 是在 SDL&#xff08;Simple DirectMed…

常用設計模式詳解

設計模式 1.UML圖 統一建模語言是用來設計軟件的可視化建模語言。定義了用例圖、類圖、對象圖、狀態圖、活動圖、時序圖、協作圖、構件圖、部署圖等 9 種圖。 1.1類圖 1.1.1類的表示方式 在UML類圖中&#xff0c;類使用包含類名、屬性(field) 和方法(method) 且帶有分割線…

基本正則表達式

基本正則表達式 正則命令功能&#xff3e;尖角號&#xff0c;用于模式的最左側&#xff0c;如“^oldbpy"&#xff0c;匹配以oldboy單詞開頭的行$美元符&#xff0c;用于模式的最右側&#xff0c;如"oldboy$"&#xff0c;表示以oldboy單詞結尾的行^$組合符&…

Java基于springboot的廚藝交流平臺的設計與實現代碼

摘 要 使用舊方法對廚藝交流信息進行系統化管理已經不再讓人們信賴了&#xff0c;把現在的網絡信息技術運用在廚藝交流信息的管理上面可以解決許多信息管理上面的難題&#xff0c;比如處理數據時間很長&#xff0c;數據存在錯誤不能及時糾正等問題。 這次開發的廚藝交流平臺功…

如何優雅的刪除undo表空間

前言 因磁盤空間不足&#xff0c;需要將undo表空間遷移到其它的存儲空間 本文介紹如何優雅的刪除undo表空間&#xff0c;并在新的存儲空間中創建新的undo表空間 詳細操作步驟如下&#xff1a; 1、查看默認undo表空間 SQL>show parameter undo NAME …

Redis的主從搭建

1.準備兩臺機器&#xff0c;安裝好redis 2.修改從服務器的redis配置 slaveof <masterip> <masterport>兩個參數 masterip 主的ip 主的端口號 masterport 3. 啟動redis 1.先啟動主機redis 2.再啟用從機redis 主機redis日志打印 從機redis 日志打印

【python】1.python3.12.2和pycharm社區版的安裝指南

歡迎來CILMY23的博客喔&#xff0c;本篇為【python】1.python3.12.2和pycharm社區版的安裝指南&#xff0c;感謝觀看&#xff0c;支持的可以給個一鍵三連&#xff0c;點贊關注收藏。 目錄 一、python3.12.2的下載與安裝 1.1下載 1.2安裝 二、pycharm的安裝 2.1下載安裝 2…

Bootstrap的使用

目錄 js的引入&#xff1a; 1.行內式 2.嵌入式 3.外鏈式 Bootstrap:的引入 注意事項&#xff1a; 條件注釋語句&#xff1a; 柵格系統&#xff1a; 列嵌套&#xff1a; 列偏移&#xff1a; 列排序&#xff1a; 響應式工具&#xff1a; Bootstrap的字體圖標的使用&a…

2024最新算法:河馬優化算法(Hippopotamus optimization algorithm,HO)求解23個基準函數,提供MATLAB代碼

一、河馬優化算法 河馬優化算法&#xff08;Hippopotamus optimization algorithm&#xff0c;HO&#xff09;由Amiri等人于2024年提出&#xff0c;該算法模擬了河馬在河流或池塘中的位置更新、針對捕食者的防御策略以及規避方法。河馬優化算法的靈感來自河馬生活中觀察到的三…

【金三銀四】Mysgl優化了解?什么情況下會導致SQL索引失效?如何寫出高效SQL與優化慢SQL

Mysgl優化 MySQL 優化是指對 MySQL 數據庫的配置、表設計、查詢語句等進行針對性的優化&#xff0c;以提高數據庫的性能和效率。這包括但不限于合理設計數據庫表結構、編寫高效的 SQL 查詢語句、創建合適的索引以及調整數據庫服務器的參數等。 當MySQL單表記錄數過大時&#xf…

【測試工具】Fiddler

1.Fiddler簡介 Fiddler是位于客戶端和服務器端的HTTP代理&#xff0c;能夠記錄客戶端和服務器之間的所有 HTTP請求&#xff0c;是web調試的利器。既然是代理&#xff0c;也就是說&#xff1a;客戶端的所有請求都要先經過Fiddler&#xff0c;然后轉發到相應的服務器&#xff0c…