Nginx+keepalived雙機(jī)熱備技術(shù)實踐
前言
在互聯(lián)網(wǎng)的高可用性 服務(wù)中,單一的服務(wù)節(jié)點往往無法滿足業(yè)務(wù)對穩(wěn)定性和可用性的要求。雙機(jī)熱備是一種常見的高可用性解決方案,它通過兩臺服務(wù)器同時運行相同的服務(wù),并使用 Keepalived 來實現(xiàn)故障轉(zhuǎn)移,確保在主服務(wù)器發(fā)生故障時,備服務(wù)器能夠立即接管服務(wù),從而保證服務(wù)的連續(xù)性。本文將詳細(xì)介紹如何在 Nginx 環(huán)境中部署雙機(jī)熱備方案。
環(huán)境準(zhǔn)備
- 兩臺 Linux 服務(wù)器(本文以 CentOS 7 為例)
- Nginx 服務(wù)器軟件
- Keepalived 軟件
- 一個可用的 IPv4 地址段(本文假設(shè)為 192.168.1.0/24)
- 兩個不同的虛擬 IP 地址(VIP,本文假設(shè)為 192.168.1.100 和 192.168.1.101)
步驟概覽
- 在兩臺服務(wù)器上安裝 Nginx 和 Keepalived。
- 配置 Nginx 以提供相同的服務(wù)。
- 配置 Keepalived 以實現(xiàn)故障轉(zhuǎn)移。
- 測試雙機(jī)熱備功能。
安裝 Nginx 和 Keepalived
# 安裝 Nginx yum install nginx -y # 啟動 Nginx 并設(shè)置開機(jī)自啟 systemctl start nginx systemctl enable nginx # 安裝 Keepalived yum install keepalived -y
配置 Nginx
在兩臺服務(wù)器上配置相同的 Nginx 服務(wù),例如,提供一個簡單的 HTTP 服務(wù):
# nginx.conf
user nginx;
worker_processes 1;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
server {
listen 80;
server_name _;
location / {
root /usr/share/nginx/html;
index index.html index.htm;
try_files $uri $uri/ =404;
}
}
}確保兩臺服務(wù)器的 Nginx 配置文件完全相同,包括文件路徑和配置項。
配置 Keepalived
Keepalived 通過 VRRP(虛擬路由器冗余協(xié)議)來實現(xiàn)故障轉(zhuǎn)移。下面是 Keepalived 的配置示例:
# keepalived.conf
! Configuration File for keepalived
# 定義兩個虛擬路由器,對應(yīng)兩個 VIP
vrrp_instance VI_1 {
state MASTER # 主服務(wù)器設(shè)置為 MASTER
interface eth0 # 網(wǎng)卡接口
virtual_router_id 51 # 虛擬路由器 ID,兩臺服務(wù)器必須相同
priority 100 # 優(yōu)先級,主服務(wù)器的優(yōu)先級應(yīng)高于備服務(wù)器
advert_int 1 # 通告間隔,單位秒
virtual_ipaddress {
192.168.1.100 # 第一個 VIP
}
}
vrrp_instance VI_2 {
state BACKUP # 備服務(wù)器設(shè)置為 BACKUP
interface eth0
virtual_router_id 51
priority 90
advert_int 1
virtual_ipaddress {
192.168.1.101 # 第二個 VIP
}
}在主服務(wù)器上,將 ??state MASTER?? 設(shè)置為 ??state BACKUP??,并將 ??priority?? 值降低以表明它是備服務(wù)器。
啟動 Keepalived
# 啟動 Keepalived 并設(shè)置開機(jī)自啟 systemctl start keepalived systemctl enable keepalived
測試雙機(jī)熱備
在測試時,你可以通過在主服務(wù)器的 Keepalived 配置中手動設(shè)置 ??state?? 為 ??BACKUP?? 來模擬故障轉(zhuǎn)移。如果一切配置正確,當(dāng)主服務(wù)器發(fā)生故障時,備服務(wù)器應(yīng)該能夠接管 VIP,并提供服務(wù)。
總結(jié)
通過 Nginx 和 Keepalived 的結(jié)合使用,我們可以在實際的網(wǎng)絡(luò)服務(wù)和負(fù)載均衡場景中,Nginx 常被用作 HTTP 和反向代理服務(wù)器,而 keepalived 則用于實現(xiàn)高可用性(HA)的解決方案。以下是一個簡單的示例,展示了如何在 Nginx 和 keepalived 的配合下實現(xiàn)雙機(jī)熱備。
首先,你需要安裝 Nginx 和 keepalived 服務(wù)。這個示例假設(shè)你已經(jīng)有了兩個服務(wù)器,我們稱之為 Server A 和 Server B,它們都運行著 Nginx,并且你想要通過 keepalived 來實現(xiàn)它們的雙機(jī)熱備。
Nginx 配置
Nginx 的配置非常簡單,你只需要確保 Nginx 在兩個服務(wù)器上正常運行即可。以下是 Nginx 配置的一個基本示例:
http {
server {
listen 80;
location / {
# 這里是你的應(yīng)用邏輯
# 例如,返回一個簡單的 "Hello World"
return 200 'Hello World';
}
}
}keepalived 配置
keepalived 的配置稍微復(fù)雜一些,你需要在兩個服務(wù)器上配置不同的角色(vrrp_instance 中的 master 或 backup),并且確保它們能夠通過 VIP(Virtual IP Address)進(jìn)行通信。以下是一個簡單的 keepalived 配置示例:
Server A 的 keepalived 配置(作為 master)
# 確保在兩個服務(wù)器上的配置文件路徑相同
[root@server-a ~]# vim /etc/keepalived/keepalived.conf
# 配置文件內(nèi)容
! Configuration File for keepalived
# 定義一個虛擬路由器ID(VRID),例如10
vrrp_instance VI_1 {
state MASTER # 設(shè)置為master
interface eth0 # 指定接口
virtual_router_id 10 # 虛擬路由器ID
priority 200 # 優(yōu)先級,決定了哪個節(jié)點成為主節(jié)點
advert_int 1 # 通告間隔,單位秒
# 虛擬IP地址,這是客戶端訪問的IP
virtual_ipaddress {
192.168.1.100 # 假設(shè)這是你的VIP
}
}
# 啟動 keepalived
systemctl start keepalivedServer B 的 keepalived 配置(作為 backup)
# 確保在兩個服務(wù)器上的配置文件路徑相同
[root@server-b ~]# vim /etc/keepalived/keepalived.conf
# 配置文件內(nèi)容
! Configuration File for keepalived
# 定義一個虛擬路由器ID(VRID),例如10
vrrp_instance VI_1 {
state BACKUP # 設(shè)置為backup
interface eth0 # 指定接口
virtual_router_id 10 # 虛擬路由器ID
priority 100 # 優(yōu)先級,低于 Server A 的配置
advert_int 1 # 通告間隔,單位秒
# 虛擬IP地址,這是客戶端訪問的IP
virtual_ipaddress {
192.168.1.100 # 假設(shè)這是你的VIP
}
}
# 啟動 keepalived
systemctl start keepalived配置說明
- 在 keepalived 中,master 節(jié)點會一直持有 VIP,直到它不可用或者降級為 backup 節(jié)點。
- backup 節(jié)點會監(jiān)控 master 節(jié)點,如果 master 節(jié)點不可用,backup 節(jié)點會接管 VIP 并成為新的 master。
- priority 值決定了節(jié)點的優(yōu)先級,值越高,成為 master 的可能性越大。
- virtual_ipaddress 段定義了 VIP,這是客戶端實際訪問的 IP 地址。
注意事項
- 確保兩臺服務(wù)器的 keepalived.conf 文件同步更新,特別是在修改配置后。
- 確保 Nginx 在兩個服務(wù)器上都是正常運行的,并且配置相同,以便在 failover 時服務(wù)可以無縫切換。
- 定期測試 failover,以確保 keepalived 配置正確,并且能夠在需要時順利切換。
請注意,這只是一個基本的示例,實際的部署可能需要根據(jù)你的網(wǎng)絡(luò)環(huán)境、負(fù)載均衡需求和安全要求進(jìn)行調(diào)整。在生產(chǎn)環(huán)境中,你可能還需要考慮配置健康檢查、安全認(rèn)證、日志記錄等因素。在Nginx+Keepalived的雙機(jī)熱備架構(gòu)中,您需要配置兩個Nginx服務(wù)器,以及一個Keepalived實例來管理它們。以下是一個簡化的配置示例,包括Nginx配置和Keepalived配置。
Nginx配置
Nginx的配置通常包括以下幾個部分:
- 主配置文件:nginx.conf,它包含所有Nginx服務(wù)器的全局配置。
- 虛擬主機(jī)配置文件:通常位于conf.d或sites-available目錄中,每個文件對應(yīng)一個虛擬主機(jī)。
下面是一個簡單的Nginx虛擬主機(jī)配置示例:
在這個配置中,我們定義了一個名為??backend??的上游服務(wù)器組,其中包括兩個Nginx服務(wù)器。然后我們定義了一個監(jiān)聽在80端口的虛擬主機(jī),它將所有的請求代理到??backend??服務(wù)器組。
Keepalived配置
Keepalived是一個基于VRRP(虛擬路由器冗余協(xié)議)的高可用性解決方案。在Nginx+Keepalived的雙機(jī)熱備中,Keepalived用于管理Nginx服務(wù)器的健康狀態(tài),并確保只有一個Nginx服務(wù)器作為主服務(wù)器接受客戶端請求,而另一個作為備用服務(wù)器等待切換。
下面是一個簡單的Keepalived配置示例:
# 假設(shè)這個配置文件位于/etc/keepalived/keepalived.conf
vrrp_instance VI_1 {
state MASTER; # 設(shè)置當(dāng)前節(jié)點為Master
virtual_router_id 51;
priority 101; # 設(shè)置優(yōu)先級,高于備用節(jié)點
advert_int 1;
virtual_ipaddress {
192.168.1.10; # 虛擬IP地址,即客戶端訪問的IP
}
}在這個配置中,我們定義了一個名為??VI_1??的VRRP實例,它將當(dāng)前節(jié)點配置為Master。我們設(shè)置了一個虛擬IP地址??192.168.1.10??,這是客戶端訪問的IP地址,實際上是分配給Master節(jié)點的。
配置文件的位置和權(quán)限
確保Nginx配置文件位于Nginx配置目錄下,例如??/etc/nginx/conf.d/??,并且擁有正確的權(quán)限(通常是??root:root??)。Keepalived配置文件通常位于??/etc/keepalived/keepalived.conf??,同樣需要有正確的權(quán)限。
啟動和監(jiān)控
配置完成后,您需要重新啟動Nginx和Keepalived服務(wù)。使用以下命令來啟動和停止服務(wù):
systemctl start nginx systemctl start keepalived systemctl stop nginx systemctl stop keepalived systemctl status nginx systemctl status keepalived
使用??systemctl status??命令可以檢查服務(wù)的運行狀態(tài)。
健康檢查和故障轉(zhuǎn)移
Keepalived通過發(fā)送VRRP通告來確定節(jié)點的健康狀態(tài)。如果Master節(jié)點出現(xiàn)故障,Keepalived會自動將備用節(jié)點提升為Master。您可以在Keepalived配置中添加健康檢查腳本,以確保只有健康的Nginx服務(wù)器才能成為Master。
# 假設(shè)這個配置文件位于/etc/keepalived/keepalived.conf
...
check_script chk_nginx {
script "killall -0 nginx || exit 1";
interval 2;
weight 2;
}
vrrp_instance VI_1 {
...
track_script {
chk_nginx;
}
}在這個例子中,我們定義了一個名為??chk_nginx??的健康檢查腳本,它通過
到此這篇關(guān)于Nginx+keepalived雙機(jī)熱備技術(shù)實踐的文章就介紹到這了,更多相關(guān)Nginx keepalived雙機(jī)熱備內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 生產(chǎn)環(huán)境部署Nginx服務(wù)器雙機(jī)熱備部署keepalived的步驟(多種模式教程)
- Nginx結(jié)合keepalived實現(xiàn)雙機(jī)熱備方案
- Nginx雙機(jī)熱備的實現(xiàn)步驟
- Nginx+Keepalived實現(xiàn)雙機(jī)熱備
- keepalived雙機(jī)熱備nginx的配置方法
- Nginx+Tomcat負(fù)載均衡群集全過程
- Nginx部署負(fù)載均衡服務(wù)的步驟全解析
- nginx負(fù)載均衡配置方式
- nginx負(fù)載均衡及詳細(xì)配置方法
- nginx實現(xiàn)負(fù)載均衡與實例解讀
- Nginx實現(xiàn)負(fù)載均衡的配置步驟
- nginx tcp負(fù)載均衡的具體實現(xiàn)
- keepalived+nginx+httpd實現(xiàn)的雙機(jī)熱備+負(fù)載均衡
相關(guān)文章
Nginx服務(wù)LNMP之WordPress部署流程步驟
這篇文章主要為大家介紹了Nginx服務(wù)LNMP之WordPress部署流程步驟,本實驗意在部署過程,使用單機(jī)版部署,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-03-03
nginx proxy_buffer_size解決后端服務(wù)傳輸數(shù)據(jù)過多,header過大問題
這篇文章主要介紹了nginx proxy_buffer_size解決后端服務(wù)傳輸數(shù)據(jù)過多,header過大問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12
NGINX 配置內(nèi)網(wǎng)訪問的實現(xiàn)步驟
本文主要介紹了NGINX 配置內(nèi)網(wǎng)訪問的實現(xiàn)步驟,Nginx的geo模塊限制域名訪問權(quán)限,僅允許內(nèi)網(wǎng)/辦公室IP訪問,具有一定的參考價值,感興趣的可以了解一下2025-05-05

