nginx可以很方便的配置成反向代理服務器:
server?{ listen?80; server_name?localhost; location?/?{ proxy_pass?http://x.x.x.x:9500; proxy_set_header?host?$host:80; proxy_set_header?x-real-ip?$remote_addr; proxy_set_header?x-forwarded-for?$proxy_add_x_forwarded_for; proxy_set_header?via?"nginx"; } }
但是如果nginx的監聽端口不是默認的80端口,改為其他端口如81端口。
后端服務器中request.getserverport()無法獲得正確的端口,返回的仍然是80;
在response.sendredirect()時,客戶端可能無法獲得正確的重定向url。
正確的配置方法下面我們詳細來看:
增加nginx虛擬主機
要做nginx的轉發,當然就要對nginx做配置。可以通過添加虛擬主機配置來增強nginx的功能。首先看看nginx的配置文件,筆者的nginx文件是在/etc/nginx/nginx.conf。從上圖可以看到nginx在最后引入了vhosts.d目錄下的配置文件。那么就要在/etc/nginx/vhosts.d目錄下創建以.conf為后綴的文件(如果該目錄不存在需要自己創建)。
nginx做非80端口轉發
要做轉發,可以使用nginx的proxy_pass配置項。nginx監聽80端口,接收到請求之后就會轉發到要轉發的url。具體的配置如下:
server?{ ??server_name?www.test.com ??listen?80; ??location?/?{ ????proxy_pass?http://127.0.0.1:8080; ??} }
是的,就是這么簡單就可以了。這是配置端口轉發的核心。
但是,當遇到需要獲取真實ip的業務時,還需要添加關于真實ip的配置:
server?{ ??server_name?www.test.com ??listen?80; ??location?/?{ ????proxy_pass?http://127.0.0.1:8080; ????proxy_set_header?host?$host:80; ????proxy_set_header?x-real-ip?$remote_addr; ????proxy_set_header?x-forwarded-for?$proxy_add_x_forwarded_for; ??} }
proxy_set_header這句配置是改變http的請求頭。而host是請求的主機名,x-real-ip是請求的真實ip,x-forwarded-for表示請求是由誰發起的。
? 版權聲明
文章版權歸作者所有,未經允許請勿轉載。
THE END