1、經常使用設置php
1、日誌格式html
log_format main '$time_iso8601|$remote_addr|$remote_user|$request_method|$uri|' '$status|$request_time|$request_length|$body_bytes_sent|$bytes_sent|' '$connection|$http_x_forwarded_for|$upstream_addr|$upstream_status|' '$upstream_response_time|$args|$http_referer|$http_user_agent'; access_log logs/access.log main;
2、反向代理透傳客戶端IP設置瀏覽器
proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
3、全局變量服務器
$args #這個變量等於請求行中的參數。 $content_length #請求頭中的Content-length字段。 $content_type #請求頭中的Content-Type字段。 $document_root #當前請求在root指令中指定的值。 $host #請求主機頭字段,不然爲服務器名稱。 $http_user_agent #客戶端agent信息 $http_cookie #客戶端cookie信息 $limit_rate #這個變量能夠限制鏈接速率。 $request_body_file #客戶端請求主體信息的臨時文件名。 $request_method #客戶端請求的動做,一般爲GET或POST。 $remote_addr #客戶端的IP地址。 $remote_port #客戶端的端口。 $remote_user #已經通過Auth Basic Module驗證的用戶名。 $request_filename #當前請求的文件路徑,由root或alias指令與URI請求生成。 $query_string #與$args相同。 $scheme #HTTP方法(如http,https)。 $server_protocol #請求使用的協議,一般是HTTP/1.0或HTTP/1.1。 $server_addr #服務器地址,在完成一次系統調用後能夠肯定這個值。 $server_name #服務器名稱。 $server_port #請求到達服務器的端口號。 $request_uri #包含請求參數的原始URI,不包含主機名,如:」/foo/bar.php?arg=baz」。 $uri #不帶請求參數的當前URI,$uri不包含主機名,如」/foo/bar.html」。 $document_uri #與$uri相同。
2、Rewrite規則cookie
語法:rewrite 正則 替換 標誌位url
flag標記(rewrite指令的最後一項參數):代理
1.last last是終止當前location的rewrite檢測,但會繼續重試location匹配並處理區塊中的rewrite規則。
日誌
2.break break是終止當前location的rewrite檢測,並且再也不進行location匹配。
code
3.redirect 返回302臨時重定向,瀏覽器地址會顯示跳轉後的URL地址。
orm
4.permanent 返回301永久重定向,瀏覽器地址會顯示跳轉後的URL地址。
例:
# 正則匹配 location ~ ^/(a|bb|ccc)/ { rewrite ^/([a-z]+)/(.*)$ http://106.185.48.229/$2?$1; } # 注:用括號括起來的參數爲後面的 $1 $2 變量
3、反向代理的路由策略
Location的配置:
語法:
location [=|~|~*|^~] /uri/ {…}
語法說明:
= 開頭表示精確匹配,不支持正則。
^~ 開頭表示uri以某個常規字符串開頭,不支持正則,理解爲匹配url路徑便可。
~和~* 開頭表示區分大小寫的和不區分大小寫的正則匹配。
!~和!~* 開頭表示區分大小寫不匹配及不區分大小寫不匹配的正則匹配。
/ 通用匹配,任何請求都會匹配,一般放着配置的最後。
匹配優先級:
= > ^~ > ~, ~* > 空
全匹配 > 路徑匹配 > 正則匹配 > 字符串匹配
示例:
# 字符串匹配 location /static { alias /home/www/static; access_log off; } # 路徑匹配,此時proxy_pass的結束 / 決定是否帶上匹配的路徑 location ^~ /333/ { proxy_pass http://106.185.48.229/; } # 正則匹配,此時proxy_pass不能帶結束 / location ~ ^/(xxx|yyy)/ { proxy_pass http://106.185.48.229; } # 字符串匹配,此時proxy_pass的結束 / 決定是否帶上匹配得路徑 location /zzz/ { proxy_pass http://106.185.48.229/; } # 默認匹配 location / { proxy_pass http://127.0.0.1:8080; }