亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

keepalived實(shí)現(xiàn)nginx高可用

 更新時(shí)間:2017年10月23日 15:34:45   作者:逍遙無謂  
這篇文章主要為大家詳細(xì)介紹了keepalived實(shí)現(xiàn)nginx高可用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

keepalived直譯就是保持存活,在網(wǎng)絡(luò)里面就是保持在線了,也就是所謂的高可用或熱備,用來防止單點(diǎn)故障(單點(diǎn)故障是指一旦某一點(diǎn)出現(xiàn)故障就會(huì)導(dǎo)致整個(gè)系統(tǒng)架構(gòu)的不可用)的發(fā)生,keepalived實(shí)現(xiàn)的基礎(chǔ)是vrrp,至于vrrp是什么請(qǐng)直接看這里vrrp,下面我們直接看應(yīng)用吧。

keepalived使用

為了方便使用,寫了一個(gè)基于ubuntu 16.04 server 的一鍵配置腳本,配置使用相關(guān)就在腳本里見吧

#!/bin/bash
# nginx+keepalived 高可用一鍵腳本for ubuntu 16.04

if [ $# -ne 4 ]; then
 echo "USAGE: $0 [MASTER|BACKUP] priority interface virtual_ipaddress"
 exit 0
fi

echo -e 'Installing nginx'
apt-get install nginx -y > /dev/null 2<&1

echo -e 'Installing keepalived'
apt-get install keepalived -y > /dev/null 2<&1

echo -e 'Configuring keepalived'
if [ ! -e /etc/keepalived ];then
 mkdir /etc/keepalived
fi
cat > /etc/keepalived/keepalived.conf <<EOF
! Configuration File for keepalived
global_defs {
 notification_email {
  chencheng199211@gmail.com
 }
 notification_email_from email #表示發(fā)送通知郵件時(shí)郵件源地址是誰
 smtp_server 127.0.0.1 #表示發(fā)送email時(shí)使用的smtp服務(wù)器地址,這里可以用本地的sendmail來實(shí)現(xiàn)
 smtp_connect_timeout 30
 router_id master #機(jī)器標(biāo)識(shí)
}
vrrp_script chk_nginx {
 script "/etc/keepalived/check_nginx.sh"
 interval 2 #腳本執(zhí)行間隔,單位秒
 weight -5 #腳本結(jié)果導(dǎo)致的優(yōu)先級(jí)變更:10表示優(yōu)先級(jí)+10;-10則表示優(yōu)先級(jí)-10
 fall 3
 rise 2
}

vrrp_instance VI_1 {
 state $1 #state指定instance(Initial)的初始狀態(tài),就是說在配置好后,這臺(tái)服務(wù)器的初始狀態(tài)就是這里指定的,但這里指定的不算,還是得要通過競選通過優(yōu)先級(jí)來確定,里如果這里設(shè)置為master,但如若他的優(yōu)先級(jí)不及另外一臺(tái),那么這臺(tái)在發(fā)送通告時(shí),會(huì)發(fā)送自己的優(yōu)先級(jí),另外一臺(tái)發(fā)現(xiàn)優(yōu)先級(jí)不如自己的高,那么他會(huì)就回?fù)屨紴閙aster
 interface $3 #實(shí)例綁定的網(wǎng)卡,因?yàn)樵谂渲锰摂MIP的時(shí)候必須是在已有的網(wǎng)卡上添加的
 virtual_router_id 51 #這里設(shè)置VRID,這里非常重要,相同的VRID為一個(gè)組,他將決定多播的MAC地址
 priority $2 #設(shè)置本節(jié)點(diǎn)的優(yōu)先級(jí),優(yōu)先級(jí)高的為master
 advert_int 2 #檢查間隔,默認(rèn)為1秒
 authentication { #這里設(shè)置認(rèn)證
  auth_type PASS #認(rèn)證方式,可以是PASS或AH兩種認(rèn)證方式
  auth_pass 1111 #認(rèn)證密碼
 }
 virtual_ipaddress { #這里設(shè)置的就是VIP,也就是虛擬IP地址,他隨著state的變化而增加刪除,當(dāng)state為master的時(shí)候就添加,當(dāng)state為backup的時(shí)候刪除,這里主要是有優(yōu)先級(jí)來決定的,和state設(shè)置的值沒有多大關(guān)系,這里可以設(shè)置多個(gè)IP地址
  $4
 }
 track_script {
  chk_nginx
 }

 #dont_track_primary:忽略VRRP的interface錯(cuò)誤
 #track_interface:跟蹤接口,設(shè)置額外的監(jiān)控,里面任意一塊網(wǎng)卡出現(xiàn)問題,都會(huì)進(jìn)入故障(FAULT)狀態(tài),例如,用nginx做均衡器的時(shí)候,內(nèi)網(wǎng)必須正常工作,如果內(nèi)網(wǎng)出問題了,這個(gè)均衡器也就無法運(yùn)作了,所以必須對(duì)內(nèi)外網(wǎng)同時(shí)做健康檢查
 #mcast_src_ip:發(fā)送多播數(shù)據(jù)包時(shí)的源IP地址,這里注意了,這里實(shí)際上就是在那個(gè)地址上發(fā)送VRRP通告,這個(gè)非常重要,一定要選擇穩(wěn)定的網(wǎng)卡端口來發(fā)送,這里相當(dāng)于heartbeat的心跳端口,如果沒有設(shè)置那么就用默認(rèn)的綁定的網(wǎng)卡的IP,也就是interface指定的IP地址
 #garp_master_delay:在切換到master狀態(tài)后,延遲進(jìn)行免費(fèi)的ARP(gratuitous ARP)請(qǐng)求
 #virtual_routes:原理和virtual ipaddress一樣,只不過這里是增加和刪除路由
 #lvs_sync_daemon_interface:lvs syncd綁定的網(wǎng)卡
 #nopreempt:設(shè)置不搶占,這里只能設(shè)置在state為backup的節(jié)點(diǎn)上,而且這個(gè)節(jié)點(diǎn)的優(yōu)先級(jí)必須別另外的高。當(dāng)主mysql恢復(fù)后不搶占資源
 #preempt_delay:搶占延遲
 #debug:debug級(jí)別
 #notify_master:表示當(dāng)切換到master狀態(tài)時(shí),要執(zhí)行的腳本
 #notify_backup:表示當(dāng)切換到backup狀態(tài)時(shí),要執(zhí)行的腳本
 #notify_fault:
}
EOF

cat > /etc/keepalived/check_nginx.sh <<EOF
#!/bin/bash
# description:
# 定時(shí)查看nginx是否存在,如果不存在則啟動(dòng)nginx
# 如果啟動(dòng)失敗,則停止keepalived
status=$(ps -C nginx --no-heading | wc -l)
if [ "${status}" = "0" ]; then
  service nginx start
  sleep 2
  status2=$(ps -C nginx --no-heading | wc -l)
  if [ "${status2}" = "0" ]; then
    /etc/init.d/keepalived stop
  fi
fi
EOF

echo -e "enable boot and starting"
service keepalived start
service nginx start

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • linux ssh端口轉(zhuǎn)發(fā)的三種方式

    linux ssh端口轉(zhuǎn)發(fā)的三種方式

    這篇文章主要介紹了linux ssh端口轉(zhuǎn)發(fā)的三種方式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • ubuntu下安裝Java 8的步驟教程

    ubuntu下安裝Java 8的步驟教程

    這篇文章主要介紹了ubuntu下Java 8的安裝步驟,文中通過一步步的步驟介紹很詳細(xì),對(duì)大家具有一定的參考價(jià)值,有需要的朋友們下面來一起看看吧。
    2017-01-01
  • linux停止jar包進(jìn)程方式

    linux停止jar包進(jìn)程方式

    這篇文章主要介紹了linux如何停止jar包進(jìn)程問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • Linux基線檢查與安全加固方式

    Linux基線檢查與安全加固方式

    本文詳細(xì)介紹了Linux安全加固的多個(gè)方面,包括賬戶管理、口令策略、SSH安全設(shè)置等,首先,對(duì)于賬戶管理,介紹了口令鎖定策略、口令生存期、口令復(fù)雜度、密碼重用限制以及禁止存在空密碼賬戶等方面的檢查和加固操作,其次,在服務(wù)管理方面
    2024-10-10
  • 在LINUX系統(tǒng)上使用rsync命令詳解

    在LINUX系統(tǒng)上使用rsync命令詳解

    rsync是一款多功能的文件同步工具,支持增量備份,減少數(shù)據(jù)傳輸時(shí)間和帶寬,它可以與不同的shell和協(xié)議配合使用,確保數(shù)據(jù)傳輸?shù)陌踩?提供了詳細(xì)的安裝和使用指南,適用于多種Linux發(fā)行版,使用戶能夠輕松掌握和應(yīng)用,Rsync的命令選項(xiàng)豐富
    2024-10-10
  • Linux SSH 安全策略 限制 IP 登錄方法

    Linux SSH 安全策略 限制 IP 登錄方法

    Linux SSH 安全策略 限制 IP 登錄方法,使用linux的朋友可以參考下
    2012-07-07
  • Linux?socket函數(shù)詳解

    Linux?socket函數(shù)詳解

    在網(wǎng)絡(luò)編程中,協(xié)議是指計(jì)算機(jī)系統(tǒng)之間進(jìn)行通信和交互所遵循的規(guī)則和約定,協(xié)議在網(wǎng)絡(luò)編程中起著舉足輕重的作用,它定義了通信雙方的行為規(guī)范,確保了網(wǎng)絡(luò)通信的順利進(jìn)行,這篇文章主要介紹了Linux?socket函數(shù),需要的朋友可以參考下
    2024-02-02
  • centos8安裝圖解(超詳細(xì)教程)

    centos8安裝圖解(超詳細(xì)教程)

    CentOS 完全遵守 Red Hat 的再發(fā)行政策,并且致力與上游產(chǎn)品在功能上完全兼容。這篇文章主要介紹了centos8安裝圖解,最詳細(xì)的一篇教程,本文圖文子相結(jié)合給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2019-10-10
  • Linux后臺(tái)運(yùn)行jar程序的流程步驟

    Linux后臺(tái)運(yùn)行jar程序的流程步驟

    在Linux系統(tǒng)中,有時(shí)候我們需要將Java程序以后臺(tái)進(jìn)程的方式運(yùn)行,以便在關(guān)閉終端或退出登錄時(shí)仍然保持程序的運(yùn)行狀態(tài),本文將介紹如何在Linux中后臺(tái)運(yùn)行一個(gè)Java的jar程序,需要的朋友可以參考下
    2024-09-09
  • Linux超詳細(xì)gcc升級(jí)全過程

    Linux超詳細(xì)gcc升級(jí)全過程

    大家好,本篇文章主要介紹了Linux超詳細(xì)gcc升級(jí)全過程,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏,方便下次瀏覽
    2021-11-11

最新評(píng)論