欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Nginx使用Keepalived部署web集群(高可用高性能負(fù)載均衡)實(shí)戰(zhàn)案例

 更新時(shí)間:2025年05月17日 15:27:09   作者:Wan@Technology Stack  
本文介紹Nginx+Keepalived實(shí)現(xiàn)Web集群高可用負(fù)載均衡的部署與測(cè)試,涵蓋架構(gòu)設(shè)計(jì)、環(huán)境配置、健康檢查、故障切換及VIP漂移驗(yàn)證,確保服務(wù)高可用性與性能

前言

Keepalived 作為一個(gè)高性能的集群高可用解決方案。提供了集群節(jié)點(diǎn)心跳檢測(cè)、健康檢查以及故障切換的功能。原生支持 LVS 負(fù)載均衡集群。除了原生支持的LVS + Keepalived 外,現(xiàn)在 Nginx + Keepalived 也比較常用。接下來(lái),我將詳細(xì)介紹 Nginx + Keepalived。

一、架構(gòu)設(shè)計(jì)

負(fù)載均衡方案系統(tǒng)架構(gòu)拓?fù)鋱D

二、環(huán)境準(zhǔn)備

rolehostipsoftware installedOS
Nginx proxy、Keepalive MASTERnode01192.168.5.11Nginx-1.10.0、keepalivedCentos 7.8
Nginx proxy、Keepalive BACKUPnode02192.168.5.12Nginx-1.10.0、keepalivedCentos 7.8
nginx web server1node03192.168.5.13Nginx-1.18.0Centos 7.8
nginx web server1node04192.168.5.14Nginx-1.18.0Centos 7.8
Clientnode05192.168.5.15----Centos 7.8

三、案例部署

配置 前端 Keepalived

---node01
[root@node01 ~]# vim /etc/keepalived/keepalived.conf 
! Configuration File for keepalived

global_defs {
   notification_email {
     acassen@firewall.loc
     failover@firewall.loc
     sysadmin@firewall.loc
   }
   notification_email_from Alexandre.Cassen@firewall.loc
   smtp_server 192.168.5.10
   smtp_connect_timeout 30
   router_id LVS_DEVEL1
}
vrrp_script check_nginx_service {
   script "/etc/keepalived/check_web_server_keepalive.sh"
   #script "killall -0 nginx"
   interval 2
}

vrrp_instance VI_1 {
    state MASTER
    interface ens33
    virtual_router_id 51
    priority 200
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    track_script {
       check_nginx_service
    }
    virtual_ipaddress {
        192.168.5.100
    }
}

[root@node01 ~]# systemctl restart keepalived.service



---node02
! Configuration File for keepalived

global_defs {
   notification_email {
     acassen@firewall.loc
     failover@firewall.loc
     sysadmin@firewall.loc
   }
   notification_email_from Alexandre.Cassen@firewall.loc
   smtp_server 192.168.5.10
   smtp_connect_timeout 30
   router_id LVS_DEVEL2
}
vrrp_script check_nginx_service {
   script "/etc/keepalived/check_web_server_keepalive.sh"
   #script "killall -0 nginx"
   interval 2
}

vrrp_instance VI_1 {
    state BACKUP
    interface ens33
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    track_script {
       check_nginx_service
    }
    virtual_ipaddress {
        192.168.5.100
    }
}

[root@node02 ~]# systemctl restart keepalived.service

配置 前端 Nginx 負(fù)載均衡

---node01
[root@node01 ~]# mv /etc/nginx/conf.d/default.conf{,.bak}
[root@node01 ~]# vim /etc/nginx/conf.d/vhost.conf
upstream nginx_keepalived_webservers {
   server 192.168.5.13:80 weight=1;
   server 192.168.5.14:80 weight=1;
}

server{
    listen       80;
    server_name  wan.ngin_keepalived.org;
    location / {
       proxy_set_header X-Forwarded-For $remote_addr;
       proxy_pass http://nginx_keepalived_webservers;
      }   
}

[root@node01 ~]# systemctl restart nginx


node02
[root@node02 ~]# mv /etc/nginx/conf.d/default.conf{,.bak}
[root@node02 ~]# vim /etc/nginx/conf.d/vhost.conf
upstream nginx_keepalived_webservers {
   server 192.168.5.13:80 weight=1;
   server 192.168.5.14:80 weight=1;
}

server{
    listen       80;
    server_name  wan.ngin_keepalived.org;
    location / {
       proxy_set_header X-Forwarded-For $remote_addr;
       proxy_pass http://nginx_keepalived_webservers;
      }   
}

[root@node02 ~]# systemctl restart nginx

配置前端 Nginx監(jiān)控腳本

---node01
[root@node01 ~]# vim /etc/keepalived/check_web_server_keepalive.sh
#!/bin/bash

http_status=`ps -C nginx --no-header | wc -l`
if [ $http_status -eq 0 ];then
   systemctl start nginx
   sleep 3
   if [ `ps -C nginx --no-header | wc -l` -eq 0 ]
   then
       systemctl stop keepalived
   fi
fi


[root@node02 ~]# vim /etc/keepalived/check_web_server_keepalive.sh
#!/bin/bash

http_status=`ps -C nginx --no-header | wc -l`
if [ $http_status -eq 0 ];then
   systemctl start nginx
   sleep 3
   if [ `ps -C nginx --no-header | wc -l` -eq 0 ]
   then
       systemctl stop keepalived
   fi
fi

配置后端 web 服務(wù)

---node03
[root@node03 ~]# yum install nginx-1.18.0-1.el7.ngx.x86_64.rpm -y
[root@node03 ~]# echo "`hostname -I` web test page..." > /usr/share/nginx/html/index.html
[root@node03 ~]# systemctl enable --now nginx


----node04
[root@node04 ~]# yum install nginx-1.18.0-1.el7.ngx.x86_64.rpm -y
[root@node04 ~]# echo "`hostname -I` web test page..." > /usr/share/nginx/html/index.html
[root@node04 ~]# systemctl enable --now nginx

客戶端訪問(wèn) VIP

實(shí)現(xiàn) Web 服務(wù)負(fù)載均衡 !

四、測(cè)試

node05 添加hosts解析

1、Keepalived 健康檢查

檢測(cè) VIP 訪問(wèn) Web 服務(wù)

模擬后端服務(wù)故障

[root@node04 ~]# systemctl stop nginx
[root@node04 ~]# systemctl is-active nginx
inactive

檢測(cè) VIP 訪問(wèn) Web 服務(wù)

模擬后端服務(wù)故障恢復(fù)

[root@node04 ~]# systemctl start nginx
[root@node04 ~]# systemctl is-active nginx
active

檢測(cè) VIP 訪問(wèn) Web 服務(wù)

注:Nginx upstream 模塊默認(rèn)支持對(duì)后端服務(wù)健康監(jiān)測(cè),Haproxy 同樣也自帶這種功能!

2、Keepalived MASTER/BACKUP 切換

查看keeapalived VIP 地址狀況

node01

node02

模擬 Keepalived MASTER 故障

[root@node01 ~]# systemctl stop keepalived.service

node01

node02

web 服務(wù)訪問(wèn)不受影響

模擬 Keepalived MASTER 故障恢復(fù)

[root@node01 ~]# systemctl start keepalived.service

node01

node02

實(shí)現(xiàn) keeapalived VIP 漂移 !
測(cè)試前端 Nginx 負(fù)載均衡服務(wù)器
node01

Nginx 服務(wù)異常后 自動(dòng)啟動(dòng)!

node02

Web 訪問(wèn)不受影響

模擬node01 nginx 服務(wù)無(wú)法啟動(dòng)

node01

node02

Web 訪問(wèn)不受影響

到此這篇關(guān)于Nginx使用Keepalived部署web集群(高可用高性能負(fù)載均衡)實(shí)戰(zhàn)案例的文章就介紹到這了,更多相關(guān)Nginx使用Keepalived部署web集群內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 云服務(wù)器寶塔面板的安裝圖文教程詳解

    云服務(wù)器寶塔面板的安裝圖文教程詳解

    這篇文章主要介紹了云服務(wù)器寶塔面板的安裝教程,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-02-02
  • 跨域(CORS)問(wèn)題的解決方案分享

    跨域(CORS)問(wèn)題的解決方案分享

    跨域是指跨域名的訪問(wèn),如果域名和端口都相同,但是請(qǐng)求路徑不同,不屬于跨域??缬虿灰欢〞?huì)有跨域問(wèn)題。因?yàn)榭缬騿?wèn)題是瀏覽器對(duì)于ajax請(qǐng)求的一種安全限制:一個(gè)頁(yè)面發(fā)起的ajax請(qǐng)求,只能是于當(dāng)前頁(yè)同域名的路徑,這能有效的阻止跨站攻擊。
    2023-02-02
  • dubbo的配置文件詳解(推薦)

    dubbo的配置文件詳解(推薦)

    這篇文章主要介紹了dubbo 配置文件詳解(推薦),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-10-10
  • Apache?Hudi基于華米科技應(yīng)用湖倉(cāng)一體化改造

    Apache?Hudi基于華米科技應(yīng)用湖倉(cāng)一體化改造

    這篇文章主要介紹了Apache?Hudi基于華米科技應(yīng)用湖倉(cāng)一體化改造?,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-03-03
  • rsync指定ssh端口進(jìn)行文件同步的方法

    rsync指定ssh端口進(jìn)行文件同步的方法

    這篇文章主要介紹了rsync指定ssh端口進(jìn)行文件同步的方法,需要的朋友可以參考下
    2018-02-02
  • Apache教程Hudi與Hive集成手冊(cè)

    Apache教程Hudi與Hive集成手冊(cè)

    這篇文章主要介紹了Apache教程Hudi與Hive集成手冊(cè),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-03-03
  • Nodejs創(chuàng)建TCP服務(wù)器 - king0222

    Nodejs創(chuàng)建TCP服務(wù)器 - king0222

    這篇文章主要介紹了Nodejs創(chuàng)建TCP服務(wù)器 - king0222的相關(guān)資料,需要的朋友可以參考下
    2015-09-09
  • 詳解阿里云服務(wù)器添加安全組規(guī)則(圖文教程)

    詳解阿里云服務(wù)器添加安全組規(guī)則(圖文教程)

    這篇文章主要介紹了詳解阿里云服務(wù)器添加安全組規(guī)則(圖文教程),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07
  • 通過(guò)cmd?連接阿里云服務(wù)器的操作方法

    通過(guò)cmd?連接阿里云服務(wù)器的操作方法

    這篇文章主要介紹了通過(guò)cmd連接阿里云服務(wù)器,在這里講一下買完服務(wù)器的要做的第一步就是去服務(wù)器的后臺(tái)做相應(yīng)的操作,本文通過(guò)兩種方法給大家講解連接服務(wù)器,需要的朋友可以參考下
    2022-04-04
  • 解析服務(wù)器常見錯(cuò)誤代碼500、501、502、503、504、505

    解析服務(wù)器常見錯(cuò)誤代碼500、501、502、503、504、505

    這篇文章主要介紹了服務(wù)器常見錯(cuò)誤代碼500、501、502、503、504、505的相關(guān)知識(shí),需要的的朋友參考下吧
    2017-05-05

最新評(píng)論