反向代理nginx 二級(jí)域名 配置及綁定方法
??一、應(yīng)用場(chǎng)景
??我們經(jīng)常會(huì)遇到在同一臺(tái)服務(wù)器建立多個(gè)Web站點(diǎn)的情況,普遍的做法是為不同的站點(diǎn)配置不同的端口,這樣就可以用IP:Port的形式訪問。
??但是用IP訪問畢竟不方便,不生動(dòng),不容易記憶。那么,我們可以給每個(gè)站點(diǎn)綁定不同的域名。(在這里我們僅談公網(wǎng)情況)即使我們只有一個(gè)域名,我們可以設(shè)置多個(gè)二級(jí)域名,使用Nginx很容易實(shí)現(xiàn)。
??二、基本要求
??通常,網(wǎng)上教程會(huì)直接貼一段配置文件的代碼,告訴我們?nèi)绱诉@般就Ok了。但我發(fā)現(xiàn)很多新手看著教程配置,并不能像博主那樣就Success了,所以接下來我們談一下基本原理。
??首先,要有一個(gè)自己能管理的域名,比如我有一個(gè) postmsg.cn 的域名,就可以生出多個(gè)子域名,二世三世千萬世……
??其次,有一臺(tái)能訪問的公網(wǎng)服務(wù)器,可以在這臺(tái)服務(wù)器上建立自己的Web站點(diǎn),一個(gè)兩個(gè)三四個(gè),對(duì)應(yīng)端口不一。
??然后,就是域名和站點(diǎn)的綁定,一個(gè)蘿卜一個(gè)坑,當(dāng)然也可以多個(gè)蘿卜一個(gè)坑……
??三、一般配置
??需要配置的地方有兩個(gè),我們先談首要先決條件,也是有些新手容易忽略的地方。
??1、域名配置
??把域名的A記錄解析指向我們的公網(wǎng)服務(wù)器,這一點(diǎn)一般人都能想到。解析的時(shí)候只能加IP,是不能帶端口號(hào)的,即只能使用默認(rèn)的80端口。(不討論域名轉(zhuǎn)發(fā))
??若想實(shí)現(xiàn)子域名綁定,在域名解析的時(shí)候必須配置合理。否則只靠Nginx是不行的。
??例如我要把子域名 p.postmsg.cn 綁定到 服務(wù)器的 8001端口,我首先要保證訪問 p.postmsg.cn 的請(qǐng)求能到達(dá)該服務(wù)器,然后Nginx才能處理。
??此時(shí),要么在域名A記錄解析里加一條 p 的主機(jī)記錄,要么主機(jī)記錄里有通配符 * 的配置(*.postmsg.cn的訪問全部解析到對(duì)應(yīng)的服務(wù)器,慎用),只設(shè)置@和www肯定是不行的。
??2、主機(jī)配置
??域名的請(qǐng)求到達(dá)主機(jī)之后,一切才可以交給Nginx來處理。
??修改Nginx配置的時(shí)候,可以直接在默認(rèn)配置文件(例如/etc/nginx/nginx.conf,如以下代碼片段所示)里修改,也可以在某個(gè)目錄下新建獨(dú)立的配置文件,然后 include 這個(gè)目錄下的配置文件(如第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塊可以寫在一個(gè)單獨(dú)文件里,在nginx.conf里包含該文件,同時(shí),支持嵌套 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 對(duì)應(yīng)配置的域名,proxy_pass對(duì)應(yīng)代理的真實(shí)地址。
??3、注意事項(xiàng)一
??一定要把 80 端口留給負(fù)責(zé)代理的Nginx。我們可以在一個(gè)服務(wù)器上同時(shí)使用Apache httpd,Nginx,Tomcat,但是域名解析只能使用默認(rèn)的80端口,負(fù)責(zé)代理的同志要拿到第一手請(qǐng)求。
??4、注意事項(xiàng)二
??即時(shí)生效性。有的朋友感覺自己配置的都對(duì),也重啟服務(wù)了,可就是看不到想要的結(jié)果。這里有三個(gè)方面的可能因素。
??域名解析生效時(shí)間。阿里云的域名最低生效時(shí)間是10分鐘,有時(shí)候可能大于這個(gè)值。
??本地DNS緩存??稍贑MD使用 ipconfig /flushdns 命令刷新本地DNS緩存。
??瀏覽器緩存。這個(gè)可能才是最不容易發(fā)現(xiàn)的,尤其是谷歌瀏覽器。F12之后,右鍵左上角地址欄邊上的刷新按鈕,點(diǎn)擊清空緩存并硬性重新加載。
??服務(wù)未重啟。service nginx restart 有時(shí)候可能沒有先 stop, 再 start 好用。
??四、總結(jié)
??本文閑扯了利用Nginx實(shí)現(xiàn)多域名代理的相關(guān)事宜。以上所述是小編給大家介紹的nginx反向代理二級(jí)域名綁定方法及注意事項(xiàng),希望對(duì)大家有所幫助,小伙伴們要想獲得更多nginx 二級(jí)域名 配置的內(nèi)容,請(qǐng)關(guān)注新網(wǎng)!
聲明:免責(zé)聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻(xiàn)自行上傳,本網(wǎng)站不擁有所有權(quán),也不承認(rèn)相關(guān)法律責(zé)任。如果您發(fā)現(xiàn)本社區(qū)中有涉嫌抄襲的內(nèi)容,請(qǐng)發(fā)
送郵件至:operations@xinnet.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),本站將立刻刪除涉嫌侵權(quán)內(nèi)容。本站原創(chuàng)內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)
需注明出處:新網(wǎng)idc知識(shí)百科