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

Nginx之upstream被動(dòng)式重試機(jī)制的實(shí)現(xiàn)

 更新時(shí)間:2025年03月02日 11:13:47   作者:池562  
本文主要介紹了Nginx之upstream被動(dòng)式重試機(jī)制的實(shí)現(xiàn),可以通過(guò)proxy_next_upstream來(lái)自定義配置,具有一定的參考價(jià)值,感興趣的可以了解一下

我們使用Nginx通過(guò)反向代理做負(fù)載均衡時(shí),如果被代理的其中一個(gè)服務(wù)發(fā)生錯(cuò)誤或者超時(shí)的時(shí)候,通常希望Nginx自動(dòng)重試其他的服務(wù),從而實(shí)現(xiàn)服務(wù)的高可用性。實(shí)際上Nginx本身默認(rèn)會(huì)有錯(cuò)誤重試機(jī)制,并且可以通過(guò)proxy_next_upstream來(lái)自定義配置。

Nginx 通過(guò) proxy_next_upstream 參數(shù)來(lái)定義什么情況下會(huì)被認(rèn)為是 fails,從而觸發(fā)失敗重試機(jī)制。

fails 可以分成兩類(lèi):

  • 默認(rèn)錯(cuò)誤,包括 error、timeout
  • 選擇定義錯(cuò)誤,包含 invalid_header 以及各種異常 http 狀態(tài)碼錯(cuò)誤等

默認(rèn)錯(cuò)誤

出現(xiàn) error 的場(chǎng)景,常見(jiàn)的是上游服務(wù)器的服務(wù)重啟、停止,或者異常崩潰導(dǎo)致的無(wú)法提供正常服務(wù)。而 timeout 的情況,就是代理請(qǐng)求過(guò)程中達(dá)到對(duì)應(yīng)的超時(shí)配置,主要包括了:

  • proxy_connect_timeout,建立三次握手的時(shí)間
  • proxy_read_timeout,建立連接后,等待上游服務(wù)器響應(yīng)以及處理請(qǐng)求的時(shí)間
  • proxy_send_timeout,數(shù)據(jù)回傳的間隔時(shí)間(注意不是數(shù)據(jù)發(fā)送耗時(shí))

選擇定義錯(cuò)誤

異常狀態(tài)碼部分(就是 4xx、5xx 錯(cuò)誤)。上游服務(wù)器返回空響應(yīng)或者非法響應(yīng)頭

invalid_header: a server returned an empty or invalid response;

其默認(rèn)值是proxy_next_upstream error timeout,即發(fā)生網(wǎng)絡(luò)錯(cuò)誤以及超時(shí),才會(huì)重試其他服務(wù)器。默認(rèn)情況下服務(wù)返回500狀態(tài)碼是不會(huì)重試的

指令配置

proxy_next_upstream

設(shè)置當(dāng)連接upstream服務(wù)器集群中的某個(gè)服務(wù)器第一次失敗時(shí),指定在哪些情況下將請(qǐng)求傳遞到下一個(gè)服務(wù)器

語(yǔ)法:	proxy_next_upstream error | timeout | invalid_header | http_500 | http_502 | http_503 | http_504 | http_403 | http_404 | http_429 | non_idempotent | off ...;
默認(rèn):	proxy_next_upstream error timeout;
使用位置:	http, ,serverlocation
  • error # 與服務(wù)器建立連接,向其傳遞請(qǐng)求或讀取響應(yīng)頭時(shí)發(fā)生錯(cuò)誤;
  • timeout # 在與服務(wù)器建立連接,向其傳遞請(qǐng)求或讀取響應(yīng)頭時(shí)發(fā)生超時(shí);
  • invalid_header # 服務(wù)器返回空的或無(wú)效的響應(yīng);
  • http_500 # 服務(wù)器返回代碼為500的響應(yīng);
  • http_502 # 服務(wù)器返回代碼為502的響應(yīng);
  • http_503 # 服務(wù)器返回代碼為503的響應(yīng);
  • http_504 # 服務(wù)器返回代碼504的響應(yīng);
  • http_403 # 服務(wù)器返回代碼為403的響應(yīng);
  • http_404 # 服務(wù)器返回代碼為404的響應(yīng);
  • http_429 # 服務(wù)器返回代碼為429的響應(yīng)(1.11.13);
  • non_idempotent # 通常,請(qǐng)求與 非冪等 方法(POST,LOCK,PATCH)不傳遞到請(qǐng)求是否已被發(fā)送到上游服務(wù)器(1.9.13)的下一個(gè)服務(wù)器; 啟用此選項(xiàng)顯式允許重試此類(lèi)請(qǐng)求;
  • off # 禁用將請(qǐng)求傳遞給下一個(gè)服務(wù)器。

當(dāng)請(qǐng)求類(lèi)型是POST時(shí),Nginx默認(rèn)不會(huì)失敗重試,如果想讓POST請(qǐng)求也會(huì)失敗重試,需要配置non_idempotent。

配置示例:

代碼語(yǔ)言:javascript

upstream nginxretry {
    server 127.0.0.1:9030 weight=10;
	server 127.0.0.1:9031 weight=10;
}
server {
    listen 9039;
    location / {
        proxy_pass http://nginxretry;
        proxy_next_upstream error timeout http_500;
    }
}

proxy_next_upstream_timeout

設(shè)置重試的超時(shí)時(shí)間,超時(shí)后不再重試,給用戶(hù)返回錯(cuò)誤,默認(rèn)為0,即不做限制

語(yǔ)法:

proxy_next_upstream_timeout time;

Default:

proxy_next_upstream_timeout 0;

Context:

http, server, location

proxy_next_upstream_tries

設(shè)置重試的最大次數(shù),若超過(guò)重試次數(shù),也不再重試,默認(rèn)為0,即不做限制(proxy_next_upstream_timeout時(shí)間內(nèi)允許proxy_next_upstream_tries次重試,包括第一次)

語(yǔ)法:

proxy_next_upstream_tries number;

Default:

proxy_next_upstream_tries 0;

Context:

http, server, location

配置示例:

server {
	proxy_next_upstream error timeout;
	proxy_next_upstream_timeout 15s;
	proxy_next_upstream_tries 5;
}

重試限制方式

默認(rèn)配置是沒(méi)有做重試機(jī)制進(jìn)行限制的,也就是會(huì)盡可能去重試直至失敗。

Nginx 提供了以下兩個(gè)參數(shù)來(lái)控制重試次數(shù)以及重試超時(shí)時(shí)間:

  • proxy_next_upstream_tries:設(shè)置重試次數(shù),默認(rèn) 0 表示無(wú)限制,該參數(shù)包含所有請(qǐng)求 upstream server 的次數(shù),包括第一次后之后所有重試之和;
  • proxy_next_upstream_timeout:設(shè)置重試最大超時(shí)時(shí)間,默認(rèn) 0 表示不限制,該參數(shù)指的是第一次連接時(shí)間加上后續(xù)重試連接時(shí)間,不包含連接上節(jié)點(diǎn)之后的處理時(shí)間

對(duì)upstream中某單一服務(wù)器的限制

  • max_fails:最大失敗次數(shù)(0為標(biāo)記一直可用,不檢查健康狀態(tài))
  • fail_timeout:失敗時(shí)間(當(dāng)fail_timeout時(shí)間內(nèi)失敗了max_fails次,標(biāo)記服務(wù)不可用fail_timeout時(shí)間后會(huì)再次激活次服務(wù))

配置示例1:

upstream httpget {
    server 192.168.111.101:8080 max_fails=5 fail_timeout=10s;
    server 192.168.111.102:8080;
}

配置示例2:

proxy_connect_timeout 3s;
proxy_next_upstream_timeout 6s;
proxy_next_upstream_tries 3;

upstream test {
    server 127.0.0.1:8001 fail_timeout=60s max_fails=2; # Server A
    server 127.0.0.1:8002 fail_timeout=60s max_fails=2; # Server B
    server 127.0.0.1:8003 fail_timeout=60s max_fails=2; # Server C
}

到此這篇關(guān)于Nginx之upstream被動(dòng)式重試機(jī)制的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Nginx upstream被動(dòng)式重試機(jī)制內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • 1分鐘搞定Nginx版本的平滑升級(jí)與回滾的方法

    1分鐘搞定Nginx版本的平滑升級(jí)與回滾的方法

    這篇文章主要介紹了1分鐘搞定Nginx版本的平滑升級(jí)與回滾的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Nginx服務(wù)安裝及軟件升級(jí)

    Nginx服務(wù)安裝及軟件升級(jí)

    這篇文章主要為大家介紹了Nginx服務(wù)的安裝以及軟件升級(jí)的步驟詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-03-03
  • Nginx查看當(dāng)前連接數(shù)的配置方法

    Nginx查看當(dāng)前連接數(shù)的配置方法

    在開(kāi)發(fā)過(guò)程中有時(shí)候我們需要查看Nginx的當(dāng)前連接數(shù),方便調(diào)整一些參數(shù)配置和性能調(diào)優(yōu),在Nginx中,你可以通過(guò)幾種方式來(lái)查看當(dāng)前的連接數(shù),感興趣的朋友一起看看吧
    2024-08-08
  • Nginx網(wǎng)站服務(wù)過(guò)程詳解

    Nginx網(wǎng)站服務(wù)過(guò)程詳解

    Nginx是一款高性能、異步非阻塞工作模式、輕量級(jí)Web服務(wù)軟件,這篇文章主要介紹了Nginx網(wǎng)站服務(wù)的相關(guān)知識(shí),需要的朋友可以參考下
    2023-06-06
  • docker nginx實(shí)現(xiàn)一個(gè)主機(jī)部署多個(gè)站點(diǎn)操作

    docker nginx實(shí)現(xiàn)一個(gè)主機(jī)部署多個(gè)站點(diǎn)操作

    這篇文章主要介紹了docker nginx實(shí)現(xiàn)一個(gè)主機(jī)部署多個(gè)站點(diǎn)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-11-11
  • Nginx結(jié)合keepalived實(shí)現(xiàn)集群

    Nginx結(jié)合keepalived實(shí)現(xiàn)集群

    本文主要介紹了Nginx結(jié)合keepalived實(shí)現(xiàn)集群,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-05-05
  • nginx+tomcat 通過(guò)域名訪問(wèn)項(xiàng)目的實(shí)例

    nginx+tomcat 通過(guò)域名訪問(wèn)項(xiàng)目的實(shí)例

    這篇文章主要介紹了nginx+tomcat 通過(guò)域名訪問(wèn)項(xiàng)目的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-05-05
  • 詳解Nginx location 匹配規(guī)則

    詳解Nginx location 匹配規(guī)則

    本篇文章主要介紹了Nginx location 匹配規(guī)則,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • Nginx配置http和https的實(shí)現(xiàn)步驟

    Nginx配置http和https的實(shí)現(xiàn)步驟

    Nginx是使用最多的代理服務(wù)器之一,本文主要介紹了Nginx配置http和https的實(shí)現(xiàn)步驟,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-03-03
  • Nginx中防止SQL注入攻擊的相關(guān)配置介紹

    Nginx中防止SQL注入攻擊的相關(guān)配置介紹

    這篇文章主要介紹了Nginx中防止SQL注入攻擊的相關(guān)配置介紹,文中提到的基本思路為將過(guò)濾的情況用rewrite重訂向到404頁(yè)面,需要的朋友可以參考下
    2016-01-01

最新評(píng)論