用Nginx做端口轉發(反向代理)

有時我們會使用一些java或node應用,但又不想讓他們直接監聽80端口,這時就需要用到端口轉發

本文中,我們介紹Nginx如何做端口轉發,還有各種轉發規則

將域名轉發到本地端口

首先介紹最常用的,將域名轉發到本地另一個端口上

server{
  listen 80;
  server_name  tomcat.shaochenfeng.com;
  index  index.php index.html index.htm;

  location / {
    proxy_pass  http://127.0.0.1:8080; # 轉發規則
    proxy_set_header Host $proxy_host; # 修改轉發請求頭,讓8080端口的應用可以受到真實的請求
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }
}

這樣訪問 http://tomcat.shaochenfeng.com 時就會轉發到本地的 8080 端口

將域名轉發到另一個域名

server{
  listen 80;
  server_name  baidu.shaochenfeng.com;
  index  index.php index.html index.htm;

  location / {
    proxy_pass  http://www.baidu.com;
    proxy_set_header Host $proxy_host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }
}

這樣訪問 http://baidu.shaochenfeng.com 時就會轉發到 http://www.baidu.com

本地一個端口轉發到另一個端口或另一個域名

server{
  listen 80;
  server_name 127.0.0.1; # 公網ip
  index  index.php index.html index.htm;

  location / {
    proxy_pass  http://127.0.0.1:8080; # 或 http://www.baidu.com
    proxy_set_header Host $proxy_host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }
}

這樣訪問 http://127.0.0.1 時就會轉發到本地的 8080 端口或 http://www.baidu.com

加 / 與不加 /

在配置proxy_pass代理轉發時,如果後面的url加/,表示絕對根路徑;如果沒有/,表示相對路徑

例如

  1. 加 /

    server_name shaochenfeng.com
    location /data/ {
    proxy_pass http://127.0.0.1/;
    }

    訪問 http://shaochenfeng.com/data/index.html 會轉發到 http://127.0.0.1/index.html

  2. 不加 /
    server_name shaochenfeng.com
    location /data/ {
    proxy_pass http://127.0.0.1;
    }

    訪問 http://shaochenfeng.com/data/index.html 會轉發到 http://127.0.0.1/data/index.html

歡迎查看更多運維技術文章 www.shaochenfeng.com

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章