Nginx配置主動(dòng)健康檢查

在使用nginx的反向代理過程中晚吞,對(duì)于服務(wù)器節(jié)點(diǎn)的健康檢查和故障轉(zhuǎn)移很重要。

早期使用nginx的時(shí)候谋国,用來做故障轉(zhuǎn)移用到的是如下配置(比較粗暴)

upstream portals 
{    
    server172.16.68.134:8082 max_fails=1 fail_timeout=5;    
    server172.16.68.135:8082 max_fails=1 fail_timeout=5;    
    server172.16.68.136:8082 max_fails=1 fail_timeout=5;    
    server172.16.68.137:8082 max_fails=1 fail_timeout=5;
}

經(jīng)過實(shí)際測試槽地,在5s內(nèi),如果第一個(gè)服務(wù)器節(jié)點(diǎn)都不返回芦瘾,在這5s內(nèi)捌蚊,請求不會(huì)向這臺(tái)服務(wù)器轉(zhuǎn)發(fā),5s的超時(shí)時(shí)間到了近弟,再次發(fā)起請求逢勾,就按照輪轉(zhuǎn)規(guī)則,該到這臺(tái)服務(wù)器還是會(huì)過去藐吮,這時(shí)候再經(jīng)歷5s溺拱,請求不會(huì)到這臺(tái)服務(wù)器。這樣子實(shí)際達(dá)不到想要的效果谣辞,在服務(wù)沒恢復(fù)以前迫摔,請求不到這臺(tái)服務(wù)器。

之后在網(wǎng)上找關(guān)于nginx健康檢查的模塊泥从、組件 句占,找到了淘寶的nginx_upstream_check_module。

安裝過程比較簡單躯嫉,nginx增加這個(gè)module的編譯即可纱烘。

Github地址:

https://github.com/yaoweibin/nginx_upstream_check_module

下載地址:

https://pan.baidu.com/s/1cSdTwiQPlIxGahjXzdCuEA

nginx、pcre的編譯目錄均默認(rèn)/home/soft祈餐,將下載的nginx_upstream_check_module-0.3.0.tar.gz上傳至/home/soft后解壓:

tar -zxvf nginx_upstream_check_module-0.3.0.tar.gz

重新編譯:

#進(jìn)入編譯目錄
cd /home/soft/nginx-1.10.1
#打補(bǔ)丁
patch -p0 < ../nginx_upstream_check_module-0.3.0/check_1.11.1+.patch
#確認(rèn)configure參數(shù)與現(xiàn)網(wǎng)一致擂啥,只增加一個(gè)module
./configure --prefix=/usr/local/nginx --with-pcre=/home/soft/pcre-8.36/  --with-http_stub_status_module --with-http_ssl_module  --add-module=/home/soft/nginx_upstream_check_module-0.3.0/
#執(zhí)行make
make
#備份現(xiàn)網(wǎng)nginx執(zhí)行文件
cd /usr/local/nginx/sbin
mv nginx nginx.old.20181016
#拷貝升級(jí)后的執(zhí)行文件到現(xiàn)網(wǎng)目錄
cp /home/soft/nginx-1.10.1/objs/nginx /usr/local/nginx/sbin
#測試nginx版本及是否正常
./nginx -V
./nginx -t

在nginx中用到的配置是:

    upstream portals {    
        server 192.166.62.137:8080;
        server 192.166.66.85:8080;
        server 192.166.62.231:8080;
        server 192.166.66.88:8080;
        check interval=5000 rise=2 fall=5 timeout=1000 type=http;    
        check_http_send"HEAD / HTTP/1.0\r\n\r\n";   check_http_expect_alive http_2xx http_3xx;
    }
    server {
        listen 8080;
        charset utf-8;
        location /status {
            check_status;
            access_log   off;
            #allow 192.166.62.25;
            #deny all;
        }
        location / {
            proxy_pass http://portal_service_pool;
            index  index.html;
        }

interval間隔5s,連續(xù)失敗5次帆阳,連續(xù)成功2次哺壶,超時(shí)時(shí)間1s,使用http協(xié)議,發(fā)送一個(gè)請求頭山宾,如果是2xx或者3xx狀態(tài)(比如200,302等)表示服務(wù)正常運(yùn)行至扰。

可以開啟注釋的配置,以使只有固定ip可以查看status頁面资锰,其他ip無法訪問此location敢课。

修改完成后reload nginx使配置生效。

sbin/nginx -s reload

觀察主動(dòng)的健康檢查效果:

image

在一臺(tái)服務(wù)器上執(zhí)行ab并發(fā)測試:

ab -n 20000 -c 10 "http://192.166.62.104:8080/PortalServer-App/index.html"

查看104上nginx日志:

tail -f logs/access.log

192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 541 "-" "ApacheBench/2.3" "-" "192.166.62.231:8080""0.002"
192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 541 "-" "ApacheBench/2.3" "-" "192.166.66.88:8080""0.002"
192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 541 "-" "ApacheBench/2.3" "-" "192.166.66.88:8080""0.002"
192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 567 "-" "ApacheBench/2.3" "-" "192.166.62.137:8080""0.001"
192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 541 "-" "ApacheBench/2.3" "-" "192.166.62.231:8080""0.001"
192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 567 "-" "ApacheBench/2.3" "-" "192.166.62.137:8080""0.000"
192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 541 "-" "ApacheBench/2.3" "-" "192.166.66.88:8080""0.002"
192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 541 "-" "ApacheBench/2.3" "-" "192.166.62.231:8080""0.001"
192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 567 "-" "ApacheBench/2.3" "-" "192.166.62.137:8080""0.001"
192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 541 "-" "ApacheBench/2.3" "-" "192.166.62.231:8080""0.001"
192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 541 "-" "ApacheBench/2.3" "-" "192.166.66.88:8080""0.002"
192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 541 "-" "ApacheBench/2.3" "-" "192.166.66.88:8080""0.002"
192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 567 "-" "ApacheBench/2.3" "-" "192.166.62.137:8080""0.001"
192.166.62.100 - - [16/Oct/2018:13:46:44 +0800] "GET /PortalServer-App/index.html HTTP/1.0" 200 541 "-" "ApacheBench/2.3" "-" "192.166.62.231:8080""0.001"

可見status中正常的后端可以被負(fù)載到绷杜,從而實(shí)現(xiàn)主動(dòng)健康檢查的效果直秆。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市接剩,隨后出現(xiàn)的幾起案子切厘,更是在濱河造成了極大的恐慌,老刑警劉巖懊缺,帶你破解...
    沈念sama閱讀 218,036評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件疫稿,死亡現(xiàn)場離奇詭異,居然都是意外死亡鹃两,警方通過查閱死者的電腦和手機(jī)遗座,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來俊扳,“玉大人途蒋,你說我怎么就攤上這事〔黾牵” “怎么了号坡?”我有些...
    開封第一講書人閱讀 164,411評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長梯醒。 經(jīng)常有香客問我宽堆,道長,這世上最難降的妖魔是什么茸习? 我笑而不...
    開封第一講書人閱讀 58,622評(píng)論 1 293
  • 正文 為了忘掉前任畜隶,我火速辦了婚禮,結(jié)果婚禮上号胚,老公的妹妹穿的比我還像新娘籽慢。我一直安慰自己,他們只是感情好猫胁,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評(píng)論 6 392
  • 文/花漫 我一把揭開白布箱亿。 她就那樣靜靜地躺著,像睡著了一般杜漠。 火紅的嫁衣襯著肌膚如雪极景。 梳的紋絲不亂的頭發(fā)上察净,一...
    開封第一講書人閱讀 51,521評(píng)論 1 304
  • 那天驾茴,我揣著相機(jī)與錄音盼樟,去河邊找鬼。 笑死锈至,一個(gè)胖子當(dāng)著我的面吹牛晨缴,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播峡捡,決...
    沈念sama閱讀 40,288評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼击碗,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了们拙?” 一聲冷哼從身側(cè)響起稍途,我...
    開封第一講書人閱讀 39,200評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎砚婆,沒想到半個(gè)月后械拍,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,644評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡装盯,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評(píng)論 3 336
  • 正文 我和宋清朗相戀三年坷虑,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片埂奈。...
    茶點(diǎn)故事閱讀 39,953評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡迄损,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出账磺,到底是詐尸還是另有隱情芹敌,我是刑警寧澤,帶...
    沈念sama閱讀 35,673評(píng)論 5 346
  • 正文 年R本政府宣布垮抗,位于F島的核電站氏捞,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏借宵。R本人自食惡果不足惜幌衣,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望壤玫。 院中可真熱鬧豁护,春花似錦、人聲如沸欲间。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽猎贴。三九已至班缎,卻和暖如春蝴光,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背达址。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評(píng)論 1 269
  • 我被黑心中介騙來泰國打工蔑祟, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人沉唠。 一個(gè)月前我還...
    沈念sama閱讀 48,119評(píng)論 3 370
  • 正文 我出身青樓疆虚,卻偏偏與公主長得像,于是被迫代替她去往敵國和親满葛。 傳聞我的和親對(duì)象是個(gè)殘疾皇子径簿,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容