校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識(shí)庫 > Vmware部署Nginx+KeepAlived集群雙主架構(gòu)的問題及解決方法

Vmware部署Nginx+KeepAlived集群雙主架構(gòu)的問題及解決方法

熱門標(biāo)簽:做外呼系統(tǒng)的公司違法嗎 寧夏房產(chǎn)智能外呼系統(tǒng)要多少錢 貴陽教育行業(yè)電話外呼系統(tǒng) 在百度地圖標(biāo)注車輛 藍(lán)點(diǎn)外呼系統(tǒng) 威海人工外呼系統(tǒng)供應(yīng)商 400電話申請(qǐng)方案 撫順移動(dòng)400電話申請(qǐng) 烏海智能電話機(jī)器人

前言

用nginx做負(fù)載均衡,作為架構(gòu)的最前端或中間層,隨著日益增長的訪問量,需要給負(fù)載均衡做高可用架構(gòu),利用keepalived解決單點(diǎn)風(fēng)險(xiǎn),一旦 nginx宕機(jī)能快速切換到備份服務(wù)器。

Vmware網(wǎng)絡(luò)配置可能遇到的問題解決方法

  • 啟動(dòng)VMware DHCP ServiceVMware NAT Service兩個(gè)服務(wù)
  • 在網(wǎng)絡(luò)適配器開啟網(wǎng)絡(luò)共享,允許其他網(wǎng)絡(luò)打勾保存,重啟虛擬機(jī)

安裝

節(jié)點(diǎn)部署

節(jié)點(diǎn) 地址 服務(wù)
centos7_1 192.168.211.130 Keepalived+Nginx
centos7_2 192.168.211.131 Keepalived+Nginx
centos7_3 192.168.211.132 Redis服務(wù)器
web1(物理機(jī)) 192.168.211.128 FastApi+Celery
web2(物理機(jī)) 192.168.211.129 FastApi+Celery

web的配置

web1啟動(dòng)python http服務(wù)器

vim index.html

<html>
<body>
<h1>Web Svr 1</h1>
</body>
</html>

nohup python -m SimpleHTTPServer 8080 > running.log 2>&1 &

web2啟動(dòng)python http服務(wù)器

vim index.html

<html>
<body>
<h1>Web Svr 2</h1>
</body>
</html>

nohup python -m SimpleHTTPServer 8080 > running.log 2>&1 &

關(guān)閉防火墻

firewall-cmd --state
systemctl stop firewalld.service
systemctl disable firewalld.service

現(xiàn)在瀏覽器訪問就正常了,頁面顯示W(wǎng)eb Svr 1 和 2

centos1和2安裝Nginx

首先配置阿里云的源

mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup
wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo
sed -i -e '/mirrors.cloud.aliyuncs.com/d' -e '/mirrors.aliyuncs.com/d' /etc/yum.repos.d/CentOS-Base.repo

安裝依賴包

yum -y install gcc
yum install -y pcre pcre-devel
yum install -y zlib zlib-devel
yum install -y openssl openssl-devel

下載nginx,并解壓

wget http://nginx.org/download/nginx-1.8.0.tar.gz
tar -zxvf nginx-1.8.0.tar.gz

安裝nginx

cd nginx-1.8.0
./configure --user=nobody --group=nobody --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_gzip_static_module --with-http_realip_module --with-http_sub_module --with-http_ssl_module
make
make install
cd /usr/local/nginx/sbin/
# 檢查配置文件
./nginx -t
# 啟動(dòng)nginx
./nginx

開放nginx訪問

firewall-cmd --zone=public --add-port=80/tcp --permanent
systemctl restart firewalld.service

此時(shí)訪問130和131都可以看到nginx的首頁。

創(chuàng)建nginx啟動(dòng)文件

需要在init.d文件夾中創(chuàng)建nginx啟動(dòng)文件。 這樣每次服務(wù)器重新啟動(dòng)init進(jìn)程都會(huì)自動(dòng)啟動(dòng)Nginx。

cd /etc/init.d/
vim nginx

#!/bin/sh
#
# nginx - this script starts and stops the nginx daemin
#
# chkconfig:   - 85 15
# description:  Nginx is an HTTP(S) server, HTTP(S) reverse \

#               proxy and IMAP/POP3 proxy server
# processname: nginx
# config:      /etc/nginx/nginx.conf
# pidfile:     /var/run/nginx.pid
# user:        nginx

# Source function library.
. /etc/rc.d/init.d/functions

# Source networking configuration.
. /etc/sysconfig/network

# Check that networking is up.
[ "$NETWORKING" = "no" ] && exit 0

nginx="/usr/local/nginx/sbin/nginx"
prog=$(basename $nginx)

NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf"

lockfile=/var/run/nginx.lock

start() {
    [ -x $nginx ] || exit 5
    [ -f $NGINX_CONF_FILE ] || exit 6
    echo -n $"Starting $prog: "
    daemon $nginx -c $NGINX_CONF_FILE
    retval=$?
    echo
    [ $retval -eq 0 ] && touch $lockfile
    return $retval
}

stop() {
    echo -n $"Stopping $prog: "
    killproc $prog -QUIT
    retval=$?
    echo
    [ $retval -eq 0 ] && rm -f $lockfile
    return $retval
}

restart() {
    configtest || return $?
    stop
    start
}

reload() {
    configtest || return $?
    echo -n $"Reloading $prog: "
    killproc $nginx -HUP
    RETVAL=$?
    echo
}

force_reload() {
    restart
}

configtest() {
  $nginx -t -c $NGINX_CONF_FILE
}

rh_status() {
    status $prog
}

rh_status_q() {
    rh_status >/dev/null 2>&1
}

case "$1" in
    start)
        rh_status_q && exit 0
        $1
        ;;
    stop)
        rh_status_q || exit 0
        $1
        ;;
    restart|configtest)
        $1
        ;;
    reload)
        rh_status_q || exit 7
        $1
        ;;
    force-reload)
        force_reload
        ;;
    status)
        rh_status
        ;;
    condrestart|try-restart)
        rh_status_q || exit 0
            ;;
    *)
        echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"
        exit 2
esac

校驗(yàn)配置文件依次輸入下列命令

chkconfig --add nginx
chkconfig --level 345 nginx on

給這個(gè)文件添加執(zhí)行權(quán)限

chmod +x nginx 
ls

functions  netconsole  network  nginx  README

啟動(dòng)Nginx服務(wù)

service nginx start
service nginx status
service nginx reload

Nginx反向代理、負(fù)載均衡(centos_1)

修改nginx.conf配置文件,去除注釋的代碼

cd /usr/local/nginx/conf/
mv nginx.conf nginx.conf.bak
egrep -v '^#' nginx.conf.bak
egrep -v '^#|^[ ]*#' nginx.conf.bak
egrep -v '^#|^[ ]*#|^$' nginx.conf.bak 
egrep -v '^#|^[ ]*#|^$' nginx.conf.bak >> nginx.conf
cat nginx.conf

輸出如下

worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    server {
        listen       80;
        server_name  localhost;
        location / {
            root   html;
            index  index.html index.htm;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}

重新加載nginx配置

# 測(cè)試配置文件是否正常
../sbin/nginx -t
# 重新加載nginx配置
../sbin/nginx -s reload

配置nginx反向代理、負(fù)載均衡

worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    
    # websvr 服務(wù)器集群(也可以叫負(fù)載均衡池)	
    upstream websvr {
        server 192.168.211.128:8001  weight=1;
        server 192.168.211.129:8001  weight=2;
    }
	
    server {
        listen       80;
        # 用來指定ip地址或者域名,多個(gè)配置之間用空格分隔
        server_name  192.168.211.130;
        location / {
            # 將所有請(qǐng)求交給websvr集群去處理
            proxy_pass http://websvr;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}

現(xiàn)在重啟nginx

sbin/nginx -s reload

websvr名稱可自定義,可以指明這些服務(wù)器的含義。也就是只需要添加upstream websvrproxy_pass就可以實(shí)現(xiàn)負(fù)載均衡。

現(xiàn)在訪問130,頁面上就會(huì)出現(xiàn)Web Svr 1和Web Svr 2切換,會(huì)根據(jù)權(quán)重選擇服務(wù)器,weight值越大,權(quán)重越高,也就是重復(fù)刷新該頁面,平均Web Svr 2出現(xiàn)2次,Web Svr 1出現(xiàn)1次。

到目前為止,仍然不能實(shí)現(xiàn)高可用,雖然web服務(wù)可以這樣做,單點(diǎn)故障可以通過這種方式處理,但是如果nginx服務(wù)故障了,整個(gè)系統(tǒng)基本就無法訪問了,那么就需要使用多臺(tái)Nginx來保障。

多個(gè)Nginx協(xié)同工作,Nginx高可用【雙機(jī)主從模式】

131服務(wù)器(centos_2)上新增一臺(tái)nginx服務(wù),和之前的配置一樣,只需要修改 nginx.conf 即可

worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;

        upstream websvr {
        server 192.168.211.128:8001  weight=1;
        server 192.168.211.129:8001  weight=2;
    }

    server {
        listen       80;
        server_name  192.168.211.131;
        location / {
            proxy_pass http://websvr;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}

# 重新加載nginx
sbin/nginx -s reload

現(xiàn)在訪問 http://192.168.211.130/ 也可以得到和 http://192.168.211.131/ 類似的結(jié)果。

這兩臺(tái)Nginx服務(wù)器的IP是不同的,那怎么做才能將這兩臺(tái)nginx服務(wù)器一起工作呢?這就需要用到keepalived了。

安裝軟件,兩臺(tái)centos同時(shí)安裝

yum install keepalived pcre-devel  -y

配置keepalived

兩臺(tái)均備份

cp /etc/keepalived/keepalived.conf keepalived.conf.bak

centos_1配置Keepalived-MASTER

[root@localhost keepalived]# cat keepalived.conf
! Configuration File for keepalived

global_defs {
    script_user root
	enable_script_security
}

vrrp_script chk_nginx {
    # 指定監(jiān)控腳本,檢測(cè)nginx服務(wù)是否正常運(yùn)行
    script "/etc/keepalived/chk_nginx.sh"
    # 指定監(jiān)控時(shí)間,每10s執(zhí)行一次
    interval 10
    # 腳本結(jié)果導(dǎo)致的優(yōu)先級(jí)變更,檢測(cè)失敗(腳本返回非0)則優(yōu)先級(jí) -5
    # weight -5
    # # 檢測(cè)連續(xù)2次失敗才算確定是真失敗。會(huì)用weight減少優(yōu)先級(jí)(1-255之間)
    # fall 2
    # 檢測(cè)1次成功就算成功。但不修改優(yōu)先級(jí)
    # rise 1
}

vrrp_instance VI_1 {
	# 指定keepalived的角色,主機(jī)設(shè)置為MASTER,備用機(jī)設(shè)置為BACKUP
    state BACKUP
	# 指定HA監(jiān)測(cè)網(wǎng)絡(luò)的接口。centos7使用 ip addr 獲取
    interface ens33
	# 主備的virtual_router_id必須一樣,可以設(shè)置為IP后一組:must be between 1 & 255
    virtual_router_id 51
	# 優(yōu)先級(jí)值,在同一個(gè)vrrp_instance下, MASTRE 一定要高于 BAUCKUP,MASTER恢復(fù)后,BACKUP自動(dòng)交接
    priority 90
	# VRRP 廣播周期秒數(shù),如果沒檢測(cè)到該廣播,就被認(rèn)為服務(wù)掛了,將切換主備
    advert_int 1
	# 設(shè)置驗(yàn)證類型和密碼。主從必須一樣
    authentication {
		# 設(shè)置vrrp驗(yàn)證類型,主要有PASS和AH兩種
        auth_type PASS
		# 加密的密碼,兩臺(tái)服務(wù)器一定要一樣,才能正常通信
        auth_pass 1111
    }
	track_script {
        # 執(zhí)行監(jiān)控的服務(wù),引用VRRP腳本,即在 vrrp_script 部分指定的名字。定期運(yùn)行它們來改變優(yōu)先級(jí)
        chk_nginx
    }
    virtual_ipaddress {
		# VRRP HA 虛擬地址 如果有多個(gè)VIP,繼續(xù)換行填寫
        192.168.211.140
    }
}

把配置文件發(fā)送到131節(jié)點(diǎn)

scp /etc/keepalived/keppalived.conf 192.168.211.131:/etc/keepalived/keepalived.conf

對(duì)于131節(jié)點(diǎn)只需要修改

state BACKUP
priority 90

主keepalived配置監(jiān)控腳本chk_nginx.sh

創(chuàng)建一個(gè)腳本,用于在keepalived中執(zhí)行

vi /etc/keepalived/chk_nginx.sh

#!/bin/bash
# 查看是否有 nginx進(jìn)程 把值賦給變量counter
counter=`ps -C nginx --no-header |wc -l`
# 如果沒有進(jìn)程值得為 0
if [ $counter -eq 0 ];then
    # 嘗試啟動(dòng)nginx
    echo "Keepalived Info: Try to start nginx" >> /var/log/messages
    /etc/nginx/sbin/nginx
    sleep 3
    if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
        # 輸出日至道系統(tǒng)消息
        echo "Keepalived Info: Unable to start nginx" >> /var/log/messages
        # 如果還沒沒啟動(dòng),則結(jié)束 keepalived 進(jìn)程
        # killall keepalived
        # 或者停止
        /etc/init.d/keepalived stop
        exit 1
    else
        echo "Keepalived Info: Nginx service has been restored" >> /var/log/messages
        exit 0
    fi
else
    # 狀態(tài)正常
    echo "Keepalived Info: Nginx detection is normal" >> /var/log/messages;
    exit 0
fi

接下來授予執(zhí)行權(quán)限,并測(cè)試

chmod +x chk_nginx.sh
./chk_nginx.sh

兩邊重啟keepalived

systemctl restart keepalived
systemctl status keepalived

此時(shí)訪問.140也是可以正常顯示的,也就是綁定的IP成功了。執(zhí)行前可以通過下面命令實(shí)時(shí)查看 messages 中的輸出日志

tail -f /var/log/messages 

# 如果nginx關(guān)閉
Keepalived Info: Try to start nginx
Keepalived Info: Nginx service has been restored
# nginx正常打開
Keepalived Info: Nginx detection is normal

當(dāng)nginx檢測(cè)正常,就會(huì)返回0;檢測(cè)沒有了,返回1,但是keepalived似乎不是檢測(cè)這個(gè)返回值來實(shí)現(xiàn)轉(zhuǎn)移,而是檢測(cè)keepalived服務(wù)是否存在,來釋放本地VIP后,最終轉(zhuǎn)移虛擬IP,到另一臺(tái)服務(wù)器。

參考文章

https://www.jianshu.com/p/7e8e61d34960
https://www.cnblogs.com/zhangxingeng/p/10721083.html

到此這篇關(guān)于Vmware部署Nginx+KeepAlived集群雙主架構(gòu)的文章就介紹到這了,更多相關(guān)Nginx+KeepAlived集群內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

標(biāo)簽:銅川 周口 朝陽 泰州 那曲 慶陽 松原 蕪湖

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Vmware部署Nginx+KeepAlived集群雙主架構(gòu)的問題及解決方法》,本文關(guān)鍵詞  Vmware,部署,Nginx+KeepAlived,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Vmware部署Nginx+KeepAlived集群雙主架構(gòu)的問題及解決方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于Vmware部署Nginx+KeepAlived集群雙主架構(gòu)的問題及解決方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    欧美精选午夜久久久乱码6080| 在线精品视频免费观看| 久久久久久久网| 国产大陆a不卡| 中文字幕成人av| 91亚洲精华国产精华精华液| 亚洲欧美视频一区| 亚洲福利国产精品| 国产在线视频一区二区| 国产日韩欧美一区二区三区综合| 成人国产亚洲欧美成人综合网| 自拍偷拍国产亚洲| 欧美日韩一区二区在线观看视频| 免费观看在线色综合| 久久先锋影音av鲁色资源网| k8久久久一区二区三区| 亚洲国产人成综合网站| 日韩欧美在线影院| 丁香婷婷深情五月亚洲| 亚洲精品成人悠悠色影视| 7777精品伊人久久久大香线蕉经典版下载 | 视频一区二区中文字幕| 欧美va在线播放| 波多野结衣欧美| 午夜影视日本亚洲欧洲精品| 欧美精品一区在线观看| 91网页版在线| 免费高清在线一区| 国产精品色呦呦| 亚洲一区二区精品久久av| 欧美在线播放高清精品| 捆绑紧缚一区二区三区视频| 国产精品高潮呻吟| 69久久99精品久久久久婷婷| 国产成人精品一区二区三区网站观看| 亚洲欧美另类小说视频| 日韩三级高清在线| av在线综合网| 奇米精品一区二区三区四区| 国产精品国产三级国产有无不卡| 欧美日韩黄色一区二区| 国产成人精品在线看| 午夜精品福利久久久| 国产欧美日韩视频一区二区| 欧美日韩精品欧美日韩精品一| 国产尤物一区二区在线| 一区二区三区在线高清| 久久亚洲捆绑美女| 欧美性视频一区二区三区| 精品国产乱码久久久久久老虎| 亚洲一二三四在线观看| 国产婷婷精品av在线| 欧美日韩一区精品| 99在线精品视频| 成人免费在线播放视频| 日韩免费一区二区| 欧洲一区二区三区在线| 国产成人午夜99999| 日日摸夜夜添夜夜添精品视频 | 国产一区二区三区黄视频| 一区二区三区影院| 国产欧美一二三区| 日本中文字幕一区二区有限公司| 欧美一区二区三级| 色悠悠久久综合| 国产美女久久久久| 五月天亚洲婷婷| 亚洲精品成a人| 国产偷国产偷亚洲高清人白洁| 日韩一区二区三区免费看| 色婷婷av一区二区三区gif| 国产成人精品在线看| 久久成人免费网站| 五月激情综合婷婷| 亚洲欧美激情在线| 国产精品区一区二区三区| 日韩一区二区视频在线观看| 欧美曰成人黄网| 一本高清dvd不卡在线观看| 国产不卡视频在线播放| 久草中文综合在线| 日本麻豆一区二区三区视频| 亚洲午夜一二三区视频| 日韩一区在线播放| 日本一区二区久久| 99久久伊人网影院| 国产成人免费av在线| 国产精品伊人色| 精品制服美女久久| 蜜臀av性久久久久av蜜臀妖精| 亚洲va韩国va欧美va| 亚洲影院理伦片| 亚洲你懂的在线视频| 一区免费观看视频| 99精品在线观看视频| 亚洲午夜一二三区视频| 一级女性全黄久久生活片免费| 中文字幕亚洲精品在线观看| 日本一区二区三区免费乱视频| 久久影音资源网| 精品国产精品网麻豆系列| 日韩欧美的一区二区| 欧美一区二区在线免费播放| 91麻豆精品国产91| 91精品国产综合久久久久久久| 欧美日韩国产精品成人| 欧美男男青年gay1069videost| 欧美午夜精品一区二区蜜桃| 欧亚一区二区三区| 欧美性猛交xxxx黑人交| 日本韩国欧美国产| 欧美影院一区二区三区| 91免费版pro下载短视频| 99r精品视频| 91欧美一区二区| 在线免费一区三区| 欧美日韩视频第一区| 欧美日韩国产不卡| 不卡免费追剧大全电视剧网站| 成人午夜av电影| 99久久伊人久久99| 欧美中文字幕一二三区视频| 欧美日韩精品一区二区在线播放| 欧美日韩免费观看一区二区三区| 欧美成人欧美edvon| 日韩三级免费观看| 久久精品视频一区二区| 国产精品国产三级国产三级人妇 | 99久久婷婷国产综合精品| 青椒成人免费视频| 狠狠色综合日日| 懂色一区二区三区免费观看| 91原创在线视频| 在线这里只有精品| 欧美日韩国产成人在线免费| 欧美岛国在线观看| 国产人伦精品一区二区| 国产精品国产三级国产有无不卡 | 久久人人爽爽爽人久久久| 欧美韩国一区二区| 亚洲精品免费播放| 肉色丝袜一区二区| 国产精品资源在线看| 99re这里只有精品视频首页| 欧美三级电影精品| 精品国产乱码久久久久久久久| 国产精品妹子av| 午夜视频久久久久久| 激情欧美日韩一区二区| 成人国产免费视频| 欧美特级限制片免费在线观看| 9人人澡人人爽人人精品| 欧美日韩免费不卡视频一区二区三区 | 色老汉av一区二区三区| 91精品综合久久久久久| 国产日韩成人精品| 一区二区日韩av| 精品亚洲porn| 色综合视频在线观看| 欧美一二三四在线| 国产日韩三级在线| 欧美影院一区二区| 欧美美女激情18p| 日本一区二区三级电影在线观看| 亚洲一区二区影院| 国产一区二区91| 色狠狠一区二区| 精品国产第一区二区三区观看体验| 亚洲婷婷在线视频| 久草中文综合在线| 欧美午夜理伦三级在线观看| 国产亚洲人成网站| 婷婷亚洲久悠悠色悠在线播放| 国产精品一区二区视频| 欧美日韩一级二级三级| 国产丝袜美腿一区二区三区| 午夜天堂影视香蕉久久| 成人在线视频一区二区| 91精品国产欧美一区二区| 亚洲欧美一区二区在线观看| 极品少妇一区二区三区精品视频| 色婷婷精品久久二区二区蜜臀av| 精品免费日韩av| 亚洲一区二区三区在线| 国产99久久久国产精品潘金| 欧美日韩国产在线观看| 国产精品全国免费观看高清 | 97精品视频在线观看自产线路二| 欧美精品日韩精品| 国产精品国产三级国产aⅴ原创| 美国三级日本三级久久99| 老色鬼精品视频在线观看播放| 99re亚洲国产精品| 久久久一区二区| 日韩中文字幕麻豆| 国产永久精品大片wwwapp| 91黄色在线观看| 欧美精品一区二区久久久| 一区二区三区成人在线视频| 成人av在线网站|