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