Nginx根據(jù)url中的path動態(tài)轉(zhuǎn)發(fā)到upstream的實現(xiàn)
在Nginx中,有一些高級場景,需要根據(jù)url中的path參數(shù),動態(tài)轉(zhuǎn)發(fā)到不通的upstream
場景1
/svr1/xxxx?yyy 轉(zhuǎn)發(fā)到 svr1:8080/xxxx?yyy
/svr2/xxxx?yyy 轉(zhuǎn)發(fā)到 svr2:8080/xxxx?yyy
配置如下:
location ~* /(srv[1-9]+)/(.*)$ { allow all; proxy_pass http://$1/$2$is_args$args; proxy_set_header Host $host; proxy_set_header x-forwarded-for $forwarded_addr; } upstream srv1 { server srv1-ip:8080; } upstream srv2 { server srv2-ip:8080; }
場景2
svc1下有3個對等服務(wù)srv1,2,3,/svc1/xxxx?yyy 轉(zhuǎn)發(fā)到,srv1/2/3:8080/xxxx?yyy
svc2下有3個對等服務(wù)srv4,5,6,/svc2/xxxx?yyy 轉(zhuǎn)發(fā)到,svr4/5/6:8080/xxxx?yyy
location ~* /(svc[1-9]+)/(.*)$ { allow all; proxy_pass http://$1/$1/$2$is_args$args; proxy_set_header Host $host; proxy_set_header x-forwarded-for $forwarded_addr; } upstream svc1 { server srv1:8080; server srv2:8080; server srv3:8080; } upstream svc2 { server srv3:8080; server srv4:8080; server srv5:8080; }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
使用nginx+lua進(jìn)行token鑒權(quán)的方法
使用nginx和lua腳本實現(xiàn)對Minio服務(wù)器圖片鏈接的token鑒權(quán),通過反向代理隱藏真實IP,增強安全性,介紹了整個鑒權(quán)流程,包括nginx配置和lua腳本的具體實現(xiàn),適用于需要保護(hù)圖片不被未授權(quán)訪問的場景2022-05-05Nginx?反向代理緩存(proxy_cache)的實現(xiàn)
Nginx的緩存加速功能是由proxy_cache和fastcgi_cache兩個功能模塊完成,本文主要介紹了Nginx?反向代理緩存(proxy_cache)的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下2024-05-05nginx.conf配置文件結(jié)構(gòu)小結(jié)
本文主要介紹了nginx.conf配置文件結(jié)構(gòu)小結(jié),nginx.conf主要由events、http、server、location、upstream等塊配置項和一些行配置項組成,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04