搭建HAProxy高可用負載均衡系統

一、HAProxy簡介

Haproxy 是一個使用C語言編寫的自由及開放源代碼軟件,其提供高可用性、負載均衡,以及==基于TCP和HTTP==的應用程序代理。

haproxy優點
1. Haproxy支持兩種代理模式 TCP(四層)和HTTP(七層),也是支持虛擬主機的。
2. Haproxy的優點能夠補充Nginx的一些缺點,比如支持Session的保持,Cookie的引導;同時支持通過獲取指定的url來檢測后端服務器的狀態。
3. Haproxy跟LVS類似,本身就只是一款負載均衡軟件;單純從效率上來講Haproxy會比Nginx有更出色的負載均衡速度,在并發處理上也是優于Nginx的。
4. Haproxy支持TCP協議的負載均衡轉發,可以對MySQL讀進行負載均衡,對后端的MySQL節點進行檢測和負載均衡,大家可以用LVS+Keepalived對MySQL主從做負載均衡。
5. HAProxy負載均衡策略非常多:Round-robin(輪循)、Weight-round-robin(帶權輪循)、source(原地址保持)、RI(請求URL)、rdp-cookie(根據cookie)。

二、實驗配置

1.安裝Haproxy,并啟用????????

dnf install haproxy -y

systemctl start haproxy
systemctl enable haproxy

2.配置服務器配置文件/etc/haproxy/haproxy.cfg

3.關閉防火墻、核心防護

[root@localhost ~]# systemctl stop firewalld
[root@localhost ~]# setenforce 0

4.重啟Haproxy,測試負載均衡

5.配置健康檢查

6.重啟并測試

for i in {1..10}; do curl http://172.25.254.100; sleep 0.5; done

7.配置ACL訪問控制

frontend webserver
bind *:80
acl block_curl hdr_sub(User-Agent) -i curl
http-request deny if block_curl
default_backend webcluster

8.重啟并測試

將curl的請求頭偽裝為Firefox 128.0 瀏覽器,繞過基于User-Agent的攔截規則。

9.配置https

1)生成自簽名證書;? ? ? ? 2)合并證書和私鑰;? ? ? ? 3)修改HAProxy配置文件

mkdir /etc/haproxy/certs
openssl req -newkey rsa:2048 -nodes -keyout /etc/haproxy/certs/haproxy.key -x509 -days 365 -out /etc/haproxy/certs/haproxy.crt

cat /etc/haproxy/certs/haproxy.key /etc/haproxy/certs/haproxy.crt > /etc/haproxy/certs/haproxy.pem

4)重啟并測試

10.配置網站狀態頁

重啟并訪問

11.動態調整后端服務器權重

1)安裝socat? ? ? ? 2)修改HAProxy配置文件? ? ? ? 3)設置權重

dnf install socat -y


[root@haproxy ~]# echo "get weight webcluster/web1" | socat stdio /var/lib/haproxy/stats
1 (initial 1)

[root@haproxy ~]# echo "get weight webcluster/web2" | socat stdio /var/lib/haproxy/stats
1 (initial 1)

[root@haproxy ~]# echo "set weight webcluster/web2 2" | socat stdio /var/lib/haproxy/stats

[root@haproxy ~]# echo "get weight webcluster/web2" | socat stdio /var/lib/haproxy/stats
2 (initial 1)

4)重啟并測試

12.配置四層負載均衡

1)修改HAProxy配置文件

2)安裝并啟動mariadb
dnf install mariadb-server -y ?# 安裝
systemctl start mariadb ? ? ? ?# 啟動
systemctl enable mariadb ? ? ? # 開機自啟

3)配置數據庫區分標識
vim /etc/my.cnf
[mysqld]
server-id=101 ?# 唯一標識,區分不同服務器

vim /etc/my.cnf
[mysqld]
server-id=102
systemctl restart mariadb

4)授權數據庫訪問
mysql -e "grant all on *.* to 'admin'@'%' identified by 'admin';"
mysql -e "flush privileges;" ?# 刷新權限

負載均衡生效

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

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

相關文章

GO語言 go get 下載 下來的包存放在哪里

在 Go 中,通過 go get(或 Go Modules 下的自動下載)獲取的第三方包,具體存儲位置取決于你是否啟用了 Go Modules(推薦方式)。? 1. 如果你使用了 Go Modules(Go 1.11 默認開啟)當前 …

PostgreSQL 14.4 ARM64 架構源碼編譯安裝指南

PostgreSQL 14.4 ARM64 架構源碼編譯安裝指南文章目錄PostgreSQL 14.4 ARM64 架構源碼編譯安裝指南說明環境要求操作系統1. 系統環境準備1.1 更新系統包1.2 創建 PostgreSQL 用戶2. 解壓 PostgreSQL 14.4 源碼包3. 配置編譯選項4. 編譯源代碼5. 安裝 PostgreSQL6. 初始化數據庫…

【科普】在STM32中有哪些定時器?

在 STM32 單片機中,定時器種類豐富,不同系列(如 F1、F4、H7 等)略有差異,以下是常見的定時器類型及核心特點:1. 基本定時器(TIM6、TIM7)功能:僅具備定時計數功能&#xf…

git使用秘訣(詳解0到1)

前言: 不知道大家有沒有使用git提交代碼或者拉取代碼的經歷,自從上一家公司實習結束以后,對git的使用歷歷在目,從一開始的add、commit到后來的pull都有著許多的疑惑。 自從有一次merge代碼以后,被師兄批了一頓以后(不小…

RHEL 9.5 離線安裝 Ansible 完整教程

文章目錄RHEL 9.5 離線安裝 Ansible 完整教程環境準備系統要求準備工作清單方法一:使用 RPM 包離線安裝步驟 1:在聯網機器上下載必要的 RPM 包步驟 2:創建本地倉庫元數據步驟 3:在離線服務器上安裝方法二:使用 Python …

44、鴻蒙HarmonyOS Next開發:視頻播放 (Video)組件和進度條 (Progress)組件的使用

目錄 視頻播放 (Video) 創建視頻組件 加載視頻資源 加載本地視頻 加載沙箱路徑視頻 加載網絡視頻 添加屬性 事件調用 Video控制器使用 其他說明 示例代碼 進度條 (Progress) 創建進度條 設置進度條樣式 場景示例 視頻播放 (Video) Video組件用于播放視頻文件并…

6、微服務架構常用十種設計模式

目錄 1、微服務架構 2、微服務架構的優點 3、微服務架構的缺點 4、何時使用微服務架構 5、微服務架構常用十種設計模式 ① 獨享數據庫(Database per Microservice) ② 事件源(Event Sourcing) ③ 命令和查詢職責分離&…

Docker 初學者需要了解的幾個知識點 (六):docker-compose.yml (ThinkPHP)

下面這個文 docker-compose.yml 文件定義了一個包含 PHP、Nginx、MySQL、Redis 的完整 ThinkPHP 開發環境,各配置項的含義如下:version: 3.8services:# PHP-FPM 服務php-fpm:image: php:8.1-fpmvolumes:- ./tp-demo:/var/www/html- ./php.ini:/usr/local…

TiDB 詳解

TiDB 詳解:架構、特性與應用實踐 TiDB 是 PingCAP 公司開發的開源分布式 NewSQL 數據庫,采用 “計算-存儲分離” 架構設計,兼具傳統關系型數據庫的 ACID 事務特性和 NoSQL 系統的水平擴展能力。以下是 TiDB 的全面技術解析。一、核心架構設計…

推客小程序商業模型設計:合規分傭體系×盈利模式×LTV提升策略

一、推客小程序的市場背景與商業價值在當今移動互聯網紅利逐漸消退的背景下,社交電商正成為流量增長的新突破口。推客小程序作為一種基于社交關系的分銷工具,完美融合了社交傳播與電商變現的雙重優勢,為企業和個人創業者提供了全新的商業機會…

Matlab處理多個循環的判斷的方式:

1、使用正則表達式:pattern strcat(\b, strjoin(tuple, \b|\b), \b);% 4. 逐行處理文件內容 modifiedContents {}; % 存儲修改后的內容 for i 1:length(fileContents)line fileContents{i};% 使用正則表達式檢查當前行是否包含元組中的任何元素if ~isempty(reg…

從字符串中“薅出”最長子串:LeetCode 340 Swift 解法全解析

文章目錄摘要描述題解答案題解代碼分析詳細解析:示例測試及結果結果解釋:時間復雜度總結摘要 在日常開發中,我們經常需要處理字符串,比如分析用戶輸入、文本挖掘、數據清洗等等。而這道題就特別實用:如何找到一個字符…

時序數據庫廠商 TDengine 發布 AI 原生的工業數據管理平臺 IDMP,“無問智推”改變數據消費范式

在工業企業越來越依賴數據驅動決策的今天,數據的獲取不再是難題,難的是從紛繁復雜的數據中提煉出有用的信息。而 AI 的崛起,正在重塑整個數據分析的邏輯。 7 月 29 日晚,TDengine 發布了一款全新產品 —— TDengine IDMP&#xf…

HBase、MongoDB 和 Redis 的區別詳解

這三者都是流行的 NoSQL 數據庫,但設計目標、數據模型和適用場景有顯著差異。以下是它們的核心對比: 1. 數據模型對比特性HBaseMongoDBRedis數據模型寬列存儲(類似 BigTable)文檔存儲(BSON/JSON)鍵值存儲&a…

設計模式之單例模式及其在多線程下的使用

很多時候,我們在使用類創建類的實例并不想可以創建很多實例對象,比如在數據庫連接的時候,對于一個數據庫的連接通常只需要連接池中的某個連接的實例,連接一次即可,對于session會話,用戶在訪問網頁做會話保持…

Apache Ignite 2.8 引入的新指標系統(New Metrics System)的完整說明

這段文檔是關于 Apache Ignite 2.8 引入的“新指標系統(New Metrics System)” 的完整說明。這是 Ignite 監控體系的一次重大升級,相比舊的、分散的統計方式,新系統更統一、靈活、可擴展。 我們來逐層拆解、通俗易懂地理解這個新…

【氮化鎵】GaN同質外延p-i-n二極管中星形與三角形擴展表面缺陷的電子特性

2025年7月23日,美國國家標準與技術研究院(NIST)與美國海軍研究實驗室的Andrew J. Winchester等人在《Applied Physics Letters》期刊發表了題為《Electronic properties of extended surface defects in homoepitaxial GaN diodes》的文章,基于光電發射電子顯微術、導電原子…

使用 Scrapy 框架定制爬蟲中間件接入淘寶 API 采集商品數據

一、引言 在電商數據分析、市場調研等領域,獲取淘寶平臺上的商品數據是一項常見需求。淘寶提供了 API 接口,允許開發者通過授權的方式獲取商品信息。本文將介紹如何使用 Scrapy 框架定制爬蟲中間件,實現對淘寶 API 的接入,從而高…

Jmeter全局變量跨線程組的使用

一、線程組1中從數據庫中查詢到字段值二、BeanShell取樣器中設置為全局變量#為什么說props.put("Out1",Out);其實是設置Out1為Jmeter的屬性了呢? 因為在后面的調試取樣器運行結果中,會發現如果只打開顯示變量開關,是看不到Out1運行…

前端技術棧詳解

前端技術棧是指構建現代Web應用程序所需的一系列技術和工具的集合。以下是當前主流前端技術棧的詳細解析&#xff1a; 一、核心基礎技術 1. HTML5 作用&#xff1a;網頁內容的結構化標記關鍵特性&#xff1a; 語義化標簽&#xff08;<header>, <section>, <arti…