首頁  >  文章  >  運維  >  nginx反向代理二級網域怎麼綁定

nginx反向代理二級網域怎麼綁定

PHPz
PHPz轉載
2023-05-20 10:55:242182瀏覽

1、應用程式場景

  我們經常會遇到在同一台伺服器建立多個web站點的情況,普遍的做法是為不同的站點配置不同的端口,這樣就可以用ip:port的形式來存取。

  但是用ip訪問畢竟不方便,不生動,不容易記憶。那麼,我們可以給每個網站綁定不同的網域。 (在這裡我們只談公網情況)即使我們只有一個域名,我們可以設定多個二級域名,使用nginx很容易實現。

2、基本需求

  通常,網路教學會直接貼一段設定檔的程式碼,告訴我們如此這般就ok了。但我發現很多新手看著教學配置,並不能像部落客一樣就success了,所以接下來我們來談談基本原理。

  首先,要有一個自己能管理的域名,比如我有一個postmsg.cn 的域名,就可以生出多個子域名,二世三世千萬世……

  其次,有一台能存取的公網伺服器,可以在這台伺服器上建立自己的web站點,一個兩個三四個,對應連接埠不一。

  然後,就是網域名稱和網站的綁定,一個蘿蔔一個坑,當然也可以多個蘿蔔一個坑…

3、一般設定

#  需要配置的地方有兩個,我們先談首要先決條件,也是有些新手容易忽略的地方。

  (1)網域設定

    把網域的a記錄解析指向我們的公網伺服器,這一點一般人都能想到。解析的時候只能加ip,是不能帶埠號的,也就是只能使用預設的80埠。 (不討論網域轉送)

    若想實現子網域名稱綁定,在網域解析的時候必須配置合理。否則只靠nginx是不行的。

    例如我要把子網域  p.postmsg.cn 綁定到 伺服器的 8001端口,我首先要保證訪問 p.postmsg.cn 的請求能到達該伺服器,然後nginx才能處理。

    此時,要麼在網域a記錄解析裡加一條p 的主機記錄,要麼主機記錄裡有通配符* 的配置(*.postmsg.cn的存取全部解析到對應的伺服器,慎用),只設定@和www肯定是不行的。

nginx反向代理二級網域怎麼綁定

                        圖1 - 域名解析示例

  (2)主機配置

    域名的請求到達主機之後,一切才可以交給nginx來處理。

    修改nginx配置的時候,可以直接在預設設定檔(例如/etc/nginx/nginx.conf,如以下程式碼片段所示)裡修改,也可以在某個目錄下新建獨立的配置文件,然後include 這個目錄下的設定檔(如第17行所示)。

http {
  log_format main '$remote_addr - $remote_user [$time_local] "$request" '
           '$status $body_bytes_sent "$http_referer" '
           '"$http_user_agent" "$http_x_forwarded_for"';
  access_log /var/log/nginx/access.log main;
  sendfile      on;
  tcp_nopush     on;
  tcp_nodelay     on;
  keepalive_timeout  65;
  types_hash_max_size 2048;
  include       /etc/nginx/mime.types;
  default_type    application/octet-stream;
  include /etc/nginx/conf.d/*.conf;
}

  這是nginx讀取設定檔的格式,我們的設定通常寫在 http { } 區塊裡,加上 server 區塊,在server區塊裡設定。剛才也說了,server塊可以寫在一個單獨文件裡,在nginx.conf裡包含該文件,同時,支援嵌套 include。

  接下來看一下 server 區塊的寫法:

server {
  listen 80;
  server_name p.postmsg.cn;
  location / {
  proxy_pass http://127.0.0.1:8008;
    proxy_redirect off;
    proxy_set_header host $host;
    proxy_set_header x-real-ip $remote_addr;
    proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for;
  }
  #access_log logs/p_access.log;
}

  這裡的 server_name 對應配置的域名,proxy_pass對應代理的真實位址。

  (3)注意事項一

    一定要把 80 埠留給負責代理的nginx。我們可以在一個伺服器上同時使用apache httpd,nginx,tomcat,但是網域解析只能使用預設的80端口,負責代理的同志要拿到第一手請求。

  (4)注意事項二

    即時生效性。有的朋友覺得自己配置的都對,也重啟服務了,可就是看不到想要的結果。這裡有三個方面的可能因素。

  1.     網域解析生效時間。阿里雲的網域最低生效時間是10分鐘,有時候可能大於這個值。

  2.     本地dns快取。 可在cmd使用 ipconfig /flushdns 指令刷新本機dns快取。

  3.     瀏覽器快取。 這可能才是最不容易發現的,尤其是Google瀏覽器。 f12之後,右鍵左上角網址列邊上的刷新按鈕,點選清空快取並硬性重新載入。

  4.     服務未重新啟動。 service nginx restart 有時候可能沒有先 stop, 再 start 好用。

#

以上是nginx反向代理二級網域怎麼綁定的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除