使用nginx+tomcat+keepalived實現(xiàn)高可用的詳細(xì)步驟
架構(gòu)設(shè)計
IP | 服務(wù)應(yīng)用 |
---|---|
192.168.166.128 | nginx/tomcat/keepalived |
192.168.166.129 | nginx/tomcat/keepalived |
192.168.166.130 | 虛擬IP |
我這是測試環(huán)境,防火墻全部關(guān)閉了。
# 查看防火墻狀態(tài) systemctl status firewalld # 關(guān)閉防火墻 systemctl stop firewalld
安裝tomcat服務(wù)
192.168.166.128
在tomcat服務(wù)webapps下創(chuàng)建一個目錄:zkc
當(dāng)前目錄:
mdkir -p webapps/zkc echo "192.168.166.128" >> webapps/zkc/a.html #啟動tomcat ./bin/startup.sh
訪問地址:http://192.168.166.128:8080/zkc/a.html
192.168.166.129
在tomcat服務(wù)webapps下創(chuàng)建一個目錄:zkc
當(dāng)前目錄:
mdkir -p webapps/zkc echo "192.168.166.129" >> webapps/zkc/a.html #啟動tomcat ./bin/startup.sh
訪問地址:http://192.168.166.129:8080/zkc/a.html
安裝nginx服務(wù)
可以直接到官網(wǎng)下載或者通過yum下載
兩臺機器安裝步驟一樣
# 安裝nginx yum -y install nginx # 進(jìn)入配置文件目錄 cd /etc/nginx/ # 修改配置文件 vim nginx.conf upstream app_server{ server 192.168.166.128:8080 weight=1 max_fails=1 fail_timeout=100; server 192.168.166.129:8080 weight=1 max_fails=1 fail_timeout=100; } server { listen 80; listen [::]:80; server_name _; root /usr/share/nginx/html; # Load configuration files for the default server block. include /etc/nginx/default.d/*.conf; location /zkc { proxy_set_header Host $host:$server_port; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_connect_timeout 10; proxy_read_timeout 600; proxy_send_timeout 600; proxy_pass http://app_server; access_log /var/log/nginx/access-app.log main; } # 啟動 nginx
訪問: curl http://192.168.166.128/zkc/a.html
訪問:curl http://192.168.166.129/zkc/a.html
安裝keepalived
安裝keepalived兩臺機器一樣
可以上網(wǎng)下載keepalived或者通過yum安裝
# 安裝 yum -y install keepalived cd /etc/keepalived/ # 創(chuàng)建檢測文件 vim chk_nginx.sh # 賦予可執(zhí)行權(quán)限 chmod +x chk_nginx.sh
chk_nginx.sh 內(nèi)容
#!/bin/bash status=$(ps aux|grep nginx | grep -v grep | grep -v bash | wc -l) #echo $status >> check.log if [ "${status}" = "0" ]; then #echo "nginx已關(guān)閉,正在重啟" >> check.log # 啟動nginx /usr/sbin/nginx status=$(ps -C nginx --no-header|wc -l) #echo $status >> check.log # 再次判斷 if [ $status -eq 0 ];then # echo "nginx已關(guān)閉,正在重啟" >> check.log # 關(guān)閉keepalived systemctl stop keepalived; fi fi
創(chuàng)建keepalived配置文件
# 備份原有keepalived.conf內(nèi)容 mv keepalived.conf keepalived.conf_bk vim keepalived.conf
global_defs { router_id LVS_Ha2 } vrrp_script chk_mysql { script "/etc/keepalived/chk_nginx.sh" interval 2 } vrrp_instance HA_1 { state BACKUP interface ens33 virtual_router_id 80 priority 80 advert_int 2 nopreempt authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.166.130 } track_script { chk_mysql } }
啟動keepalived
systemctl start keepalived
#查看虛擬IP ip add
訪問虛擬IP環(huán)境:curl http://192.168.166.130/zkc/a.html
說明環(huán)境已經(jīng)搭建成功
驗證
1、192.168.166.128 中nginx突發(fā)故障,但是keepalived使得nginx又重新啟動
2、重啟服務(wù)器模擬服務(wù)器故障死機
192.168.166.128重啟
192.168.166.129,此時發(fā)現(xiàn)虛擬IP漂移到此服務(wù)器上
為什么沒有128呢,是因為剛才服務(wù)重啟,但是tomcat、nginx、keepalived服務(wù)沒有做開機自啟。
到此這篇關(guān)于nginx+tomcat+keepalived實現(xiàn)高可用的文章就介紹到這了,更多相關(guān)nginx+tomcat+keepalived高可用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Nginx服務(wù)器屏蔽與禁止屏蔽網(wǎng)絡(luò)爬蟲的方法
今天小編就為大家分享一篇關(guān)于Nginx服務(wù)器屏蔽與禁止屏蔽網(wǎng)絡(luò)爬蟲的方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03iis+nginx實現(xiàn)負(fù)載均衡的詳細(xì)步驟
這篇文章主要為大家詳細(xì)介紹了iis+nginx實現(xiàn)負(fù)載均衡的詳細(xì)步驟 ,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07