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

Docker+Nginx+KeepaLived實(shí)現(xiàn)Nginx一主一從高可用方式

 更新時(shí)間:2025年07月24日 14:19:17   作者:抹香鯨之海  
在CentOS7主從服務(wù)器上部署Nginx容器并配置Keepalived實(shí)現(xiàn)高可用,通過(guò)虛擬IP自動(dòng)切換,主從均需安裝Keepalived,配置健康檢查腳本監(jiān)控Nginx狀態(tài),故障時(shí)自動(dòng)重啟或切換虛擬IP,需關(guān)閉防火墻和SELinux,并確保腳本有執(zhí)行權(quán)限
  • 系統(tǒng)版本 Centos7
  • IP:10.10.11.79 Master
  • IP:10.10.11.81 Slave
  • 虛擬ip:10.10.11.77

客戶端發(fā)起一個(gè)請(qǐng)求 ,請(qǐng)求沒(méi)有到Nginx的實(shí)際IP上,而是請(qǐng)求的虛擬IP(會(huì)和實(shí)際IP通過(guò)配置文件進(jìn)行綁定)

如果有一臺(tái)Nginx服務(wù)器掛了,Keepalived會(huì)自動(dòng)在備N(xiāo)ginx服務(wù)器上選一臺(tái)當(dāng)主服務(wù)器

主從兩臺(tái)機(jī)器上分別啟動(dòng)nginx容器

兩臺(tái)nginx容器要用相同的端口號(hào):

docker run -d --privileged=true --name keepalivedNginx -p 82:80 nanlist/nginx1.23.1:v1.0

在兩臺(tái)宿主機(jī)器上分別安裝 keepalived

(注意:keepalived安裝在實(shí)體機(jī)上,不是安裝到Docker容器中)

1.聯(lián)網(wǎng)下載到/usr/local目錄

并解壓有可能會(huì)提示連接不成功,加上它提示的命令再下載就好了

如果下載不下來(lái)用瀏覽器下載下來(lái)再傳到服務(wù)上面也可以

兩臺(tái)服務(wù)器分別執(zhí)行下:

  • 主:
[root@Master html]# cd /usr/local
[root@Master local]# wget https://www.keepalived.org/software/keepalived-1.4.2.tar.gz
[root@Master local]# tar -zxvf keepalived-1.4.2.tar.gz
  • 從:
[root@Slave html]# cd /usr/local
[root@Slave local]# wget https://www.keepalived.org/software/keepalived-1.4.2.tar.gz
[root@Slave local]# tar -zxvf keepalived-1.4.2.tar.gz

2.安裝相關(guān)依賴,有不用下載了

  • 主:
[root@Master local]# yum install -y gcc openssl-devel popt-devel
  • 從:
[root@Slave local]# yum install -y gcc openssl-devel popt-devel

3.編譯安裝

  • 主:
[root@Master local]# cd keepalived-1.4.2
[root@Master keepalived-1.4.2]# ./configure --prefix=/usr/local/keepalived
[root@Master keepalived-1.4.2]# make
[root@Master keepalived-1.4.2]# make install
  • 從:
[root@Slave local]# cd keepalived-1.4.2
[root@Slave keepalived-1.4.2]# ./configure --prefix=/usr/local/keepalived
[root@Slave keepalived-1.4.2]# make
[root@Slave keepalived-1.4.2]# make install

4.相關(guān)配置,按命令執(zhí)行

  • 主:
[root@Master keepalived-1.4.2]# pwd
/usr/local/keepalived-1.4.2
You have new mail in /var/spool/mail/root
[root@Master keepalived-1.4.2]# cp /usr/local/keepalived-1.4.2/keepalived/etc/init.d/keepalived /etc/init.d/
[root@Master keepalived-1.4.2]# mkdir /etc/keepalived
[root@Master keepalived-1.4.2]# cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/
[root@Master keepalived-1.4.2]# cp /usr/local/keepalived-1.4.2/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
[root@Master keepalived-1.4.2]# cp /usr/local/keepalived/sbin/keepalived /usr/sbin/

  • 從:
[root@Slave keepalived-1.4.2]# pwd
/usr/local/keepalived-1.4.2
You have new mail in /var/spool/mail/root
[root@Slave keepalived-1.4.2]# cp /usr/local/keepalived-1.4.2/keepalived/etc/init.d/keepalived /etc/init.d/
[root@Slave keepalived-1.4.2]# mkdir /etc/keepalived
[root@Slave keepalived-1.4.2]# cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/
[root@Slave keepalived-1.4.2]# cp /usr/local/keepalived-1.4.2/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
[root@Slave keepalived-1.4.2]# cp /usr/local/keepalived/sbin/keepalived /usr/sbin/
[root@Slave keepalived-1.4.2]#

安裝之后

在 /etc/keepalived目錄下有個(gè) keepalived.conf 配置文件:

主:

vim /etc/keepalived/keepalived.conf
  • 編輯內(nèi)容:
global_defs {  
	router_id LVS_DEVEL 
}  

# 檢查nginx狀態(tài)的腳本,健康監(jiān)測(cè)腳本
vrrp_script chk_nginx {
	script "/etc/keepalived/nginx_check.sh" # 腳本路徑
	interval 2 # 腳本執(zhí)行間隔時(shí)間
	weight -20
}
  
vrrp_instance VI_1 {  
    state MASTER  
    interface ens192  # 當(dāng)前進(jìn)行vrrp通訊的網(wǎng)絡(luò)接口卡(當(dāng)前centos的網(wǎng)卡) 用ifconfig查看你具體的網(wǎng)卡
    virtual_router_id 51  # 虛擬路由編號(hào),主從要一至
    priority 150 # 優(yōu)先級(jí),數(shù)值越大,獲取處理請(qǐng)求的優(yōu)先級(jí)越高 master要大于slave
	advert_int 1
	unicast_src_ip 10.10.11.79 # 本機(jī)ip
	
	track_script {
		chk_nginx
	}

    nopreempt
    authentication {  
        auth_type PASS  # 指定認(rèn)證方式。PASS簡(jiǎn)單密碼認(rèn)證(推薦),AH:IPSEC認(rèn)證(不推薦)
        auth_pass 1111  # 指定認(rèn)證所使用的密碼。最多8位
    }  
    unicast_peer { # 另外一臺(tái)的服務(wù)器ip,如果是多臺(tái)就配多個(gè)ip
        10.10.11.81
    }
    virtual_ipaddress {  # 指定VIP地址
        10.10.11.77
    }  

}  
   

從:

  • 編輯:
vim /etc/keepalived/keepalived.conf
  • 配置內(nèi)容:
global_defs {
	router_id LVS_DEVEL
}

vrrp_script chk_nginx {
	script "/etc/keepalived/nginx_check.sh"
	interval 2
	weight -20 
}

vrrp_instance VI_1 {
	state Slave
	interface ens192
	virtual_router_id 51
	priority 90
	advert_int 1
	unicast_src_ip 10.10.11.81
	unicast_peer {
		10.10.11.79
	}

	nopreempt
	authentication {
		auth_type PASS
		auth_pass 1111
	}

	track_script {
		chk_nginx
	}

	virtual_ipaddress {
		10.10.11.77
	}
}

健康監(jiān)測(cè)腳本

主從機(jī)都需配置檢測(cè)nginx是否在運(yùn)行,不在允許就直接啟動(dòng)nginx的腳本,和keepalived放在一起

腳本名稱 nginx_check.sh

如果 nginx 停止運(yùn)行,嘗試啟動(dòng),如果無(wú)法啟動(dòng)則殺死本機(jī)的 keepalived 進(jìn)程,keepalived將虛擬 ip 綁定到 BACKUP 機(jī)器上。內(nèi)容如下:

#!/bin/bash
#version 0.0.1
#當(dāng)nginx進(jìn)程不存在時(shí),會(huì)自動(dòng)重啟nginx服務(wù);
A=`ps -C nginx --no-header |wc -l`
if [ $A -eq 0 ];then
     docker restart keepalivedNginx     #重啟nginx
     sleep 2
     if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
        systemctl stop keepalived
     fi 
fi

編輯完以后放入到/etc/keepalived目錄下:

只要配置好了,以后直接啟動(dòng)keepalived就好了,keepalived運(yùn)行之后就會(huì)檢測(cè)nginx是否在運(yùn)行,不在運(yùn)行就通過(guò)腳本去啟動(dòng)

自動(dòng)重啟不了解決方案

查看腳本是否有運(yùn)行的權(quán)限

如果你是root登陸的話(不是的話,切換到root用戶,對(duì)*.sh 賦可執(zhí)行的權(quán)限)

chmod 777*.sh

或者

chmod +x *.sh

主從兩臺(tái)服務(wù)器這一步授權(quán)一定要執(zhí)行不然腳本會(huì)失效:

[root@Master keepalived]# chmod +x nginx_check.sh 
[root@Master keepalived]# ll
total 12
-rw-r--r-- 1 root root 572 Oct 12 03:55 keepalived.conf
-rw-r--r-- 1 root root 3550 Oct 12 03:48 keepalived.conf.bak
-rwxr-xr-x 1 root root 205 Oct 12 04:04 nginx_check.sh
[root@Master keepalived]#

腳本上傳以后重啟keepalived。

keepalived常用命令

  • #啟動(dòng)
service keepalived start
  • #停止
service keepalived stop
  • #查看狀態(tài)
service keepalived status

驗(yàn)證

1:如果驗(yàn)證主從是否可以自動(dòng)切換實(shí)現(xiàn)熱備效果可以把其中一臺(tái)機(jī)器的keepalived服務(wù)stop掉,然后刷新虛擬ip。

2:如果驗(yàn)證健康腳本是否生效,可以把nginx容器stop掉,過(guò)兩秒再次查看一下nginx容器是否啟動(dòng)。

注意:可能出現(xiàn)檢測(cè)腳本不執(zhí)行

可能的原因是selinux和防火墻沒(méi)有關(guān)閉

setenforce 0

vim /etc/selinux/config

將ELINUX的值修改為

ELINUX=disabled

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用docker快速部署Nginx、Redis、MySQL、Tomcat及制作鏡像的方法

    使用docker快速部署Nginx、Redis、MySQL、Tomcat及制作鏡像的方法

    這篇文章介紹了如何使用Docker快速部署Nginx、Redis、MySQL、Tomcat以及制作鏡像的過(guò)程,它涵蓋了從基礎(chǔ)鏡像的使用、Dockerfile的編寫(xiě)到應(yīng)用的構(gòu)建和部署的詳細(xì)步驟,通過(guò)本文,可以掌握如何利用Docker簡(jiǎn)化應(yīng)用的部署和管理,感興趣的朋友跟隨小編一起看看吧
    2024-11-11
  • docker?images的常用方式

    docker?images的常用方式

    這篇文章主要介紹了docker?images的常用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Docker的基本命令使用筆記

    Docker的基本命令使用筆記

    這篇文章主要介紹了Docker的基本命令使用筆記,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-06-06
  • 使用Docker部署前后端分離項(xiàng)目的完整步驟

    使用Docker部署前后端分離項(xiàng)目的完整步驟

    剛剛接觸基礎(chǔ)的運(yùn)維工作,采用的是docker部署的方式,下面這篇文章主要給大家介紹了關(guān)于使用Docker部署前后端分離項(xiàng)目的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-01-01
  • Dockerfile常用命令的使用簡(jiǎn)介

    Dockerfile常用命令的使用簡(jiǎn)介

    這篇文章主要介紹了Dockerfile常用命令的使用簡(jiǎn)介,幫助大家更好的理解和學(xué)習(xí)使用Docker,感興趣的朋友可以了解下
    2021-04-04
  • 云原生之docker命令詳解

    云原生之docker命令詳解

    Docker是一個(gè)開(kāi)源的應(yīng)用容器引擎,基于Go語(yǔ)言并遵從Apache2.0協(xié)議開(kāi)源,Docker 可以讓開(kāi)發(fā)者打包他們的應(yīng)用以及依賴包到一個(gè)輕量級(jí)、可移植的容器中,然后發(fā)布到任何流行的 Linux 機(jī)器上,也可以實(shí)現(xiàn)虛擬化,本文就給大家介紹了云原生中的docker命令
    2023-06-06
  • Docker部署Ragflow(完美解決502 bad gateway)

    Docker部署Ragflow(完美解決502 bad gateway)

    本文主要介紹了Docker部署Ragflow,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2025-04-04
  • Docker安裝RabbitMQ AMQP協(xié)議及重要角色

    Docker安裝RabbitMQ AMQP協(xié)議及重要角色

    這篇文章主要為大家介紹了Docker安裝RabbitMQ AMQP協(xié)議和主要角色詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • Docker端口占用問(wèn)題分析以及解決方案

    Docker端口占用問(wèn)題分析以及解決方案

    這篇文章主要介紹了Docker端口占用問(wèn)題分析以及解決方案,主要步驟包括檢查端口占用、處理Windows環(huán)境下的特殊問(wèn)題、解決權(quán)限問(wèn)題、修改端口映射和考慮其他可能原因,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2025-04-04
  • docker-compose中的redis-stack詳解

    docker-compose中的redis-stack詳解

    Redis是一個(gè)開(kāi)源的內(nèi)存數(shù)據(jù)結(jié)構(gòu)存儲(chǔ)系統(tǒng),主要用于數(shù)據(jù)庫(kù)、緩存和消息代理,支持多種數(shù)據(jù)結(jié)構(gòu),RedisStack則基于Redis,提供棧的操作及擴(kuò)展功能,適合復(fù)雜數(shù)據(jù)處理,本文給大家介紹docker-compose中的redis-stack,感興趣的朋友跟隨小編一起看看吧
    2024-09-09

最新評(píng)論