亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

Nginx如何根據(jù)前綴路徑轉(zhuǎn)發(fā)到不同的Flask服務(wù)

瀏覽:252日期:2023-03-13 15:37:49
目錄
  • 開端
  • 解決一(設(shè)置SCRIPT_NAME)
  • 解決二(設(shè)置頭部X-Forwarded-Prefix再用ProxyFix調(diào)整WSGI環(huán)境)
  • 兩種解決的區(qū)別
    • nginx proxy_pass配置的區(qū)別
    • 為什么需要這樣處理
  • 總結(jié)

    開端

    想通過不同的前綴路徑經(jīng)過nginx轉(zhuǎn)發(fā)到不同的服務(wù)上,比如 /user/轉(zhuǎn)發(fā)到用戶服務(wù),/other/轉(zhuǎn)發(fā)到其他服務(wù)。

    首先配置nginx的location根據(jù)前綴匹配。

    server {    listen 80;    server_name localhost;    location /user/ {    proxy_pass http://127.0.0.1:5000; # 用戶服務(wù)    }	  location /other/ {    proxy_pass http://127.0.0.1:5001; # 其他服務(wù)    }}

    這樣訪問http://127.0.0.1:5000/user/xxx/就會轉(zhuǎn)發(fā)到用戶服務(wù),訪問http://127.0.0.1:5000/other/xxx/就會轉(zhuǎn)發(fā)到其他服務(wù)。

    這樣就會有一個問題,flask application并不知道有前綴,所以使用url_for構(gòu)造url的時候并不會自己添加前綴,要構(gòu)造出正確帶前綴的url就需要把前綴加入到WSGI環(huán)境中的SCRIPT_NAME去。

    解決一(設(shè)置SCRIPT_NAME)

    gunicorn文檔上:

    可以把SCRIPT_NAME設(shè)置到環(huán)境變量中或者HTTP header中。

    通過docker部署設(shè)置SCRIPT_NAME在環(huán)境變量中,可以在docker-compose.yml中加入

    environment:  - SCRIPT_NAME=/user/

    或者把SCRIPT_NAME設(shè)置在header中可以在nginx配置中加上

    proxy_set_header SCRIPT_NAME /user/;

    gunicorn.wsgi處理請求的時候是這樣處理PATH_INFO和SCRIPT_NAME的:

    解決二(設(shè)置頭部X-Forwarded-Prefix再用ProxyFix調(diào)整WSGI環(huán)境)

    同樣的也可以ProxyFix中間件來調(diào)整WSGI環(huán)境,設(shè)置SCRIPT_NAME。

    來自werkzeug ProxyFix文檔:

    通過nginx設(shè)置頭部信息X-Forwarded-Prefix:

    proxy_set_header X-Forwarded-Prefix /user/;

    使用ProxyFix:

    from werkzeug.middleware.proxy_fix import ProxyFixapp = ProxyFix(app, x_prefix=1)

    還需要把nginx的proxy_pass修改下:

    server {    listen 80;    server_name example.com;    location /user/ {    proxy_pass http://127.0.0.1:5000/; # 用戶服務(wù)    }	  location /other/ {    proxy_pass http://127.0.0.1:5001/; # 其他服務(wù)    }}

    兩種解決的區(qū)別

    nginx proxy_pass配置的區(qū)別

    區(qū)別在于nginx的proxy_pass中結(jié)尾是否帶/。

    如果proxy_pass不帶uri,就是不帶/,則請求會原封不動的轉(zhuǎn)發(fā)給下一個服務(wù)。

    如果proxy_pass帶uri,則匹配的uri部分將會被修改為該proxy_pass中的uri。

    為什么需要這樣處理

    以我的理解是這樣的,請求進來通過gunicorn處理請求,gunicorn.wsgi中會根據(jù)SCRIPT_NAME來制定PATH_INFO,所以當解決一帶著SCRIPT_NAME=/user/,PATH_INFO=/user/xxx/經(jīng)過處理后PATH_INFO會變成/xxx/

    而解決二中當gunicorn.wsgi處理請求時ProxyFix還沒對WSGI環(huán)境進行處理,所以SCRIPT_NAME是為空的,PATH_INFO則會一直是帶著SCRIPT_NAME前綴為/user/xxx/,是不能正確匹配到route的,所以把nginx proxy_pass改為uri形式使PATH_INFO能正確匹配。

    總結(jié)

    以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持。

    標簽: Nginx
    主站蜘蛛池模板: 国产麻豆剧传媒精品国产免费 | 中文永久免费看电视网站入口 | 免费大片黄国产在线观看 | 日韩精品片 | 免费看欧美日韩一区二区三区 | 久久色图 | 国产精品二区在线 | 一级人做人a爰免费视频 | 亚洲综合激情六月婷婷在线观看 | 久久国产精品视频一区 | 亚洲精品国产综合一线久久 | 国产精品免费在线播放 | 欧美日韩一区二区三区在线 | 免费人成黄页在线观看忧物 | 性欧美一级毛片 | 草草影院地址ccyycom浮力影院37 草草影院欧美 | 精品国产综合成人亚洲区 | 亚洲国产精品va在线观看麻豆 | 欧洲美女大片免费播放器视频 | 日韩欧美一区二区三区在线 | 日韩黄色小视频 | 亚洲午夜久久久精品影院视色 | 成人国产在线视频在线观看 | 精品理论片一区二区三区 | av蜜桃| 香蕉超级碰碰碰97视频在线观看 | 蕾丝视频成人★在线观看 | 中国美女一级黄色片 | 免费网站在线看 | 中文字幕黄色片 | 91久久精品一区二区三区 | 91av视频在线观看 | 黄视频在线观看www免费 | 欧美一区二区三区在线观看不卡 | 国产色播 | 在线观看欧美亚洲 | 59pao成国产成视频永久免费 | 国产啪精品视频网给免丝袜 | 国产午夜精品久久久久免费视小说 | 精品国偷自产在线不卡短视频 | 亚洲视频在线观看网址 |