這篇文章主要介紹了Nginx服務器中配置非80端口的端口轉發方法詳解,文中使用到了Nginx中的proxy_pass配置項,需要的朋友可以參考下
nginx可以很方便的配置成反向代理服務器:
1
2
3
4
5
6
7
8
9
10
11
|
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。具體的配置如下:
1
2
3
4
5
6
7
8
|
是的,就是這么簡單就可以了。這是配置端口轉發的核心。
但是,當遇到需要獲取真實IP的業務時,還需要添加關於真實IP的配置:
1
2
3
4
5
6
7
8
9
10
11
|
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表示請求是由誰發起的。
小結
這次的配置可能對大部分人來說都很簡單,但是筆者剛接觸Nginx配置這一塊,因此記錄下來,分享給有需要的人。如有建議和批評,歡迎指出。通過這次的學習發現,Nginx的配置是很值得學習的。
轉發自:http://www.jb51.net/article/82046.htm