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肯定是不行的。
圖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)注意事項二
即時生效性。有的朋友覺得自己配置的都對,也重啟服務了,可就是看不到想要的結果。這裡有三個方面的可能因素。
網域解析生效時間。阿里雲的網域最低生效時間是10分鐘,有時候可能大於這個值。
本地dns快取。 可在cmd使用 ipconfig /flushdns 指令刷新本機dns快取。
瀏覽器快取。 這可能才是最不容易發現的,尤其是Google瀏覽器。 f12之後,右鍵左上角網址列邊上的刷新按鈕,點選清空快取並硬性重新載入。
服務未重新啟動。 service nginx restart 有時候可能沒有先 stop, 再 start 好用。
以上是nginx反向代理二級網域怎麼綁定的詳細內容。更多資訊請關注PHP中文網其他相關文章!