場景1:因服務器限制,所以只對外開放了一個端口,但是需要請求不同的外網(wǎng)環(huán)境,所以在中轉服務器上用nginx做了一次轉發(fā)
實現(xiàn):
server {
listen 8051;
server_name localhost;
location /license/ {
proxy_pass http://xxx.xxx.xxx.xxx:8058/;
}
location / {
proxy_pass http://xxx.xxx.xxx.xxx:8051/; } }
特別注意:
敲黑板:此處如果涉及到文件上傳的轉發(fā),相應在server_name下添加client_max_body_size 100m;
域名轉發(fā)的地址,proxy_pass后面必須跟"/",否則會造成轉發(fā)不正常
在nginx中配置proxy_pass代理轉發(fā)時,如果在proxy_pass后面的url加/,表示絕對根路徑;
如果沒有/,表示相對路徑,把匹配的路徑部分也給代理走。
假設下面四種情況分別用 http://192.168.1.1/proxy/aerchi.html 進行訪問。
第一種:
location /proxy/ {
proxy_pass http://127.0.0.1/;
}
代理到URL:http://127.0.0.1/aerchi.html
第二種(相對于第一種,最后少一個 / )
location /proxy/ {
proxy_pass http://127.0.0.1;
}
代理到URL:http://127.0.0.1/proxy/aerchi.html
第三種:
location /proxy/ {
proxy_pass http://127.0.0.1/aaa/;
}
代理到URL:http://127.0.0.1/aaa/aerchi.html
第四種(相對于第三種,最后少一個 / )
location /proxy/ {
proxy_pass http://127.0.0.1/aaa;
}
代理到URL:http://127.0.0.1/aaaaerchi.html
場景2:因業(yè)務需要,一套前段代碼需要映射到兩個后臺地址上,所以需要在接口上進行區(qū)分轉發(fā),同時轉發(fā)時需要把區(qū)分標志去掉
實現(xiàn):
server {
listen 0.0.0.0:8204;
server_name localhost;
# 靜態(tài)頁面目錄
root E:\xxxxxxx;
# 默認首頁
index /index.html;
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;
#proxy_cookie_path /* /*;
client_max_body_size 100m;
location ~*/wx/(.*) {#根絕接口是否包含/wx/來區(qū)分
# 動態(tài)頁面,交給tomcat處理
if ( !-e $request_filename) {
proxy_pass http://127.0.0.1:8091/$1;#轉到后臺時需要把/wx去掉
}
}
location / {
# 用戶瀏覽器端的緩存設置
location ~* \.(css|js|jpg|jpeg|gif|png|swf|htm|html|json|xml|svg|woff|ttf|eot|map|ico)$ {
expires -1;
if (-f $request_filename) {
break;
}
}
# 動態(tài)頁面,交給tomcat處理
if ( !-e $request_filename) {
proxy_pass http://127.0.0.1:8092;
#proxy_cookie_path /* /*;
}
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
特別注意:
1、 proxy_set_header Host $http_host;
不改變請求頭 。
2、proxy_set_header Host host;如果客戶端請求頭中沒有攜帶這個頭部,那么傳遞到后端服務器的請求也不含這個頭部。這種情況下,使用 host;如果客戶端請求頭中沒有攜帶這個頭部,那么傳遞到后端服務器的請求也不含這個頭部。 這種情況下,使用host;如果客戶端請求頭中沒有攜帶這個頭部,那么傳遞到后端服務器的請求也不含這個頭部。這種情況下,使用host變量它 的值在請求包含“Host”請求頭時為“Host”字段的值,在請求未攜帶“Host”請求頭時為虛擬主機的主域名;
3、proxy_set_header Host host: host:host:proxy_port;
服務器名可以和后端服務器的端口一起傳送:
4、如果某個請求頭的值為空,那么這個請求頭將不會傳送給后端服務器:
proxy_set_header Accept-Encoding “”;
5、用戶真實的ip地址轉發(fā)給后端服務器
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;
場景3:前段代碼用vue實現(xiàn),vue沒有具體的頁面,也是通過/xx/xx來訪問資源,這時候需要與后臺接口進行區(qū)分
實現(xiàn):
可以通過特殊字符類似“#”來區(qū)分,攜帶#的請求默認是靜態(tài)資源
location ~* \.(#|css|js|jpg|jpeg|gif|png|swf|htm|html|json|xml|svg|woff|ttf|eot|map|ico)$ {
expires -1;
if (-f $request_filename) {
break;
}
}
場景4:因服務器限制,數(shù)據(jù)庫訪問需要nginx進行轉發(fā)
實現(xiàn):
stream {
upstream cloudsocket {
hash $remote_addr consistent;
server 數(shù)據(jù)庫實際ip:3306 weight=5 max_fails=3 fail_timeout=30s;
}
server {
listen 127.0.0.1:8058; #本機代理端口
proxy_connect_timeout 10s;
proxy_timeout 300s;#設置客戶端和代理服務之間的超時時間,如果5分鐘內(nèi)沒操作將自動斷開。
proxy_pass cloudsocket;
}
}
特別注意:
stream與http同級,所以不要放到http里
場景5:訪問某域名時需要重定向到另一個地址
實現(xiàn):
server {
listen 7000;
server_name localhost;
client_max_body_size 100m;
location = / {
rewrite ^(.*) https://www.baidu.com permanent;
}
}
特別注意:
last 本條規(guī)則匹配完成后繼續(xù)向下匹配新的location URI規(guī)則
break 本條規(guī)則匹配完成后終止,不在匹配任何規(guī)則
redirect 返回302臨時重定向
permanent 返回301永久重定向
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。