ngx_http_proxy_module模塊:
示例:
location / {
proxy_pass http://localhost:8000;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
proxy_pass: 用戶對指定URL的請求都轉交給后端另外一台服務器
格式:
location /url { proxy_pass http://back_server:port/newurl; }
/url --> /newurl
特殊情況:
1.如果是 ~ | ~* 模式匹配的url,是可以忽略的,這種情況proxy_pass http://back_server:port/newurl/url;
2.如果location中使用了重定向的話,代理的url是重定向后的url地址
示例:
location / {
proxy_pass http://192.168.1.103/;
}
location /bbs {
proxy_pass http://192.168.1.103/bbs/;
}
location /forum {
proxy_pass http://192.168.1.103/bbs;
}
location ~* \.(jpg|png|gif)$ {
proxy_pass http://192.168.1.103; //這里是模式匹配的情況,圖片訪問時地址會加到url后面
}
proxy_set_header: 向后端發送特定首部,並且記錄真實的客戶端IP地址
格式:
location / {
proxy_set_header Host $host; // 將$host客戶端請求首部的值放到Host變量中
proxy_set_header X-Real-IP $remote_addr; //將$remote_addr客戶端ip放到X-Real-IP變量中 }
修改后端服務器日志格式:
LogFormat "%{X-Real-IP}i %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
%h --> %{X-Real-IP}i
proxy_cache_path: 設置緩存路徑及其他緩存參數
格式:
proxy_cache_path /data/nginx/cache levels=1:2 keys_zone=one:10m; //指定了磁盤空間上存放內容的位置;磁盤上內容的存放結構;內存空間中存放的鍵名字和大小;
context: http //proxy_cache_path上下文是http,只能在http配置段中配置
示例:
proxy_cache_path /cache/nginx/ levels=1:1 keys_zone=mycache:32m;
proxy_cache_methods: 客戶端使用哪一類請求才會被緩存,默認是GET和HEAD
格式:
Syntax: proxy_cache_methods GET | HEAD | POST ...;
Default:
proxy_cache_methods GET HEAD;
Context: http, server, location
This directive appeared in version 0.7.59.
proxy_cache_min_usrs:某一個請求被請求多少次才會被緩存,默認是一次
格式:
Syntax: proxy_cache_min_uses number;
Default:
proxy_cache_min_uses 1;
Context: http, server, location
proxy_cache_purge: 管理緩存空間中的緩存條目
格式:
Syntax: proxy_cache_purge string ...;
Default: —
Context: http, server, location
This directive appeared in version 1.5.7.
示例:
proxy_cache_path /data/nginx/cache keys_zone=cache_zone:10m;
map $request_method $purge_method {
PURGE 1;
default 0;
}
server {
...
location / {
proxy_pass http://backend;
proxy_cache cache_zone;
proxy_cache_key $uri;
proxy_cache_purge $purge_method;
}
}
proxy_cache_revalidate: 過期后重新校驗緩存
格式:
Syntax: proxy_cache_revalidate on | off;
Default:
proxy_cache_revalidate off;
Context: http, server, location
This directive appeared in version 1.5.7.
proxy_cache_use_stale: 是否使用已經過期的緩存響應客戶請求
格式:
Syntax: proxy_cache_use_stale error | timeout | invalid_header | updating | http_500 | http_502 | http_503 | http_504 | http_403 | http_404 | http_429 | off ...;
Default:
proxy_cache_use_stale off;
Context: http, server, location
proxy_cache_valid: 對不同響應碼設置緩存時間
格式:
Syntax: proxy_cache_valid [code ...] time;
Default: —
Context: http, server, location
示例:
proxy_cache_valid 200 302 10m;
proxy_cache_valid 301 1h;
proxy_cache_valid any 1m;
proxy_connect_timeout: 向后端發送請求連接的超時時長
格式:
Syntax: proxy_connect_timeout time;
Default:
proxy_connect_timeout 60s;
Context: http, server, location
proxy_hide_header: proxy向客戶端響應請求時隱藏首部
格式:
Syntax: proxy_hide_header field;
Default: —
Context: http, server, location
proxy_read_timeout: 代理服務器發出響應的超時時間
格式:
Syntax: proxy_read_timeout time;
Default:
proxy_read_timeout 60s;
Context: http, server, location
proxy_pass_request_headers: 是否將客戶端的請求報文中的請求首部原封不動的發到后端
格式:
Syntax: proxy_pass_request_headers on | off;
Default:
proxy_pass_request_headers on;
Context: http, server, location
proxy_pass_request_body: 是否將客戶端的請求報文中的body發到后端
格式:
Syntax: proxy_pass_request_body on | off;
Default:
proxy_pass_request_body on;
Context: http, server, location
proxy_buffers: 將代理服務器的響應放到緩沖中
格式:
Syntax: proxy_buffers number size;
Default:
proxy_buffers 8 4k|8k;
Context: http, server, location
proxy_cache_bypass: 設置在何種情形下nginx將不從cache取數據的
格式:
Syntax: proxy_cache_bypass string ...; //string的值調用內建函數:$cookie_nocache,$arg_nocache,$http_authorization Default: — Context: http, server, location