Ngx_http_proxy_module

proxy_pass

proxy_pass後的url加不加/的區別

# 在nginx中配置proxy_pass時,當在後面的url加上了/,相當於是絕對根路徑,則nginx不會把location中匹配的路徑部分代理走;# 如果沒有/,則會把匹配的路徑部分也給代理走。下面四種情況分別用http://192.168.1.4/proxy/test.html 進行訪問。
第一種:
location  /proxy/ {
          proxy_pass http://127.0.0.1:81/;
}
會被代理到http://127.0.0.1:81/test.html 這個url


第二:(相對於第一種,最後少一個 /)
location  /proxy/ {
          proxy_pass http://127.0.0.1:81;
}
會被代理到http://127.0.0.1:81/proxy/test.html 這個url


第三種:
location  /proxy/ {
          proxy_pass http://127.0.0.1:81/ftlynx/;
}
會被代理到http://127.0.0.1:81/ftlynx/test.html 這個url。


第四種情況(相對於第三種,最後少一個 / ):
location  /proxy/ {
          proxy_pass http://127.0.0.1:81/ftlynx;
}
會被代理到http://127.0.0.1:81/ftlynxtest.html 這個url


 從結果可以看出,應該說分爲兩種情況才正確。即http://127.0.0.1:81 (上面的第二種) 這種和 http://127.0.0.1:81/.... (上面的第1,3,4種) 這種。

proxy_pass實現僞源功能

server {
        listen          80;
        server_name     www.dyf.com;

        location /image {
            root            /data/www/;                     #首先讀取本地路徑資源;
            error_page      404 = /fetch$uri;               #當返回404,實現內部跳轉;
        }

        location /fetch {            
            alias           /data/www/;                     #獲取後本地保存的路徑
            proxy_pass      http://www.source.com:80/;      #pass指向的server,注意不加‘/’會將匹配路徑也追加;
            proxy_store     on;
            proxy_store_access user:rw group:rw all:rw;     #本地路徑需要開啓權限
        }
    }
    # proxy_pass 給出 
    # proxy_pass 只要執行就會走後端服務器,無論本地有無資源,所以先要進行本地判斷;
    # 當404時走proxy_pass# 保存文件的修改時間根據接收到的“Last-Modified”響應頭來設置。響應都是先寫到臨時文件,然後進行重命名來生成的。
    從0.8.9版本開始,臨時文件和持久化存儲可以放在不同的文件系統,但是需要注意這時文件執行的是在兩個文件系統間拷貝操作,而不是廉價的重命名操作。
    因此建議保存文件的路徑和proxy_temp_path指令設置的臨時文件的路徑在同一個文件系統中。
    # 由於先寫進proxy_temp_file,針對不完整文件可刪除,實現不完整數據不保存;
    # 兩個文件系統之間的copy,最好設置proxy_temp_path & save_path 爲統一路徑;
    # 統一文件系統 -- rename
    # 不同文件系統 -- copy

proxy_connect_variables

  • proxy_connect_timeout 60s;ngx 與 proxy_server 連接超時時間,不能超過75s;

  • proxy_read_timeout 60s;與proxy_server讀超時時間,決定ngx 等待多長時間去獲得 proxy_server 請求響應不是獲取整個response,而是兩次reading操作的時間.

  • proxy_send_timeout 60s;ngx 給 proxy_server 發送請求的超時時間;不是整個發送時間,而是兩次write時間;超時後仍然沒有收到數據,連接關閉。

  • ngx & proxy 建立連接 -- connect_timeout

  • ngx --> proxy 發送請求 -- send_timeout

  • ngx <-- proxy 等待響應 -- read_timeout

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章