服務(wù)器
前言
10年的羅平網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。營銷型網(wǎng)站的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整羅平建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。成都創(chuàng)新互聯(lián)公司從事“羅平網(wǎng)站設(shè)計”,“羅平網(wǎng)站推廣”以來,每個客戶項目都認(rèn)真落實執(zhí)行。在WEB開發(fā)中,我們經(jīng)常涉及到跨域的請求,解決跨域問題的方式有很多,比如有window.name、iframe、JSONP、CORS等等,就不詳細(xì)展開了,涉及到 協(xié)議、端口 不一樣的跨域請求方式是采用代理,這里我們重點聊聊Nginx代理的方式。
場景
本地啟動了一個前后端分離的WEB應(yīng)用,端口為:3000,可以通過http://127.0.0.1:3000訪問前端頁面,頁面中有些Ajax請求的地址為http://127.0.0.1:3000/api/getList,一般情況下肯定是404或者請求失敗,如下圖:
這種后端服務(wù)的接口存放在于其他的服務(wù)器中,比如在公司內(nèi)網(wǎng)可以通過http://172.30.1.123:8081/api/getList訪問到測試環(huán)境中的服務(wù)接口。
這種情況的請求就涉及到端口不一樣的跨域了,那么我們可以利用Nginx代理請求。
Nginx代理配置參考
首先找到Nginx配置文件:
Windows下路徑就是你安裝Nginx目錄下找,比如我的放在C盤根目錄,那就是:c:\\nginx\\conf\\nginx.conf Mac系統(tǒng)配置文件路徑在: /usr/local/etc/nginx/nginx.conf, Finder下通過Shift+Command+G,輸入/usr/local/etc/nginx/進入該目錄。在Nginx配置文件中添加如下配置:
server { listen 80; server_name 127.0.0.1; location / { proxy_pass http://127.0.0.1:3000; } location ~ /api/ { proxy_pass http://172.30.1.123:8081; } }
上面的配置的可以理解為:
監(jiān)聽80端口(Nginx默認(rèn)啟動了80端口),將http://127.0.0.1的所有請求服務(wù)轉(zhuǎn)發(fā)到127.0.0.1端口為3000;
將http://127.0.0.1/api/或者h(yuǎn)ttp://127.0.0.1/api/getList請求轉(zhuǎn)發(fā)到http://172.30.1.123:8081
完成
經(jīng)過上面的配置我們可以直接通過http://127.0.0.1訪問我們的WEB應(yīng)用(如果采用IP訪問),而相關(guān)的API請求也會根據(jù)我們的Nginx配置進行相應(yīng)的請求,瀏覽器端看到的/api/getList請求的是127.0.0.1端口為80的端口,但是實際上這個請求已經(jīng)被我們的Nginx轉(zhuǎn)發(fā)指向http://172.30.1.123:8081/api/getList
優(yōu)化:
基本的代理功能就像上面如此簡單的配置即可。
但是,當(dāng)我們需要獲取真實IP的業(yè)務(wù)時,還需要添加關(guān)于真實IP的配置,如下:
server { listen 80; server_name 127.0.0.1; location / { proxy_pass http://127.0.0.1:3000; 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; } location ~ /api/ { proxy_pass http://172.30.1.123:8081; 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表示請求是由誰發(fā)起的。
因為我們的Nginx在這里屬于代理服務(wù)器,通過proxy_set_header配置這些信息目的是讓服務(wù)端獲取到真實的請求頭。
友情提示:
Nginx每一條配置語句后面都必須要加分好; 否則會報配置錯誤,自己還一臉懵逼。
拓展
綁定host
如果你覺得輸入IP訪問不爽那你可以自己修改host,推薦host修改神器:SwitchHosts。
host修改參考:
127.0.0.1 www.domain.com #改成你需要的任何域名
如果綁定了host,在Nginx配置中當(dāng)然也可以直接配置你指定的域名,譬如:
server { listen 80; server_name www.domain.com; #這里將IP改成你的域名 #... }
修改host后你可以直接通過你的域名訪問,如:http://www.domain.com
關(guān)于location
上面的配置你可能會對localtion后面的配置感到疑惑,關(guān)于localtion后面的常用的需求有:
localtion / { # 所有請求都匹配以下規(guī)則 # 因為所有的地址都以 / 開頭,所以這條規(guī)則將匹配到所有請求 # xxx 你的配置寫在這里 } location = / { # 精確匹配 / ,后面帶任何字符串的地址都不符合 } localtion /api { # 匹配任何 /api 開頭的URL,包括 /api 后面任意的, 比如 /api/getList # 匹配符合以后,還要繼續(xù)往下搜索 # 只有后面的正則表達式?jīng)]有匹配到時,這一條才會采用這一條 } localtion ~ /api/abc { # 匹配任何 /api/abc 開頭的URL,包括 /api/abc 后面任意的, 比如 /api/abc/getList # 匹配符合以后,還要繼續(xù)往下搜索 # 只有后面的正則表達式?jīng)]有匹配到時,這一條才會采用這一條 } 以/ 通用匹配, 如果沒有其它匹配,任何請求都會匹配到 =開頭表示精確匹配 如 A 中只匹配根目錄結(jié)尾的請求,后面不能帶任何字符串。 ^~ 開頭表示uri以某個常規(guī)字符串開頭,不是正則匹配 ~ 開頭表示區(qū)分大小寫的正則匹配; ~* 開頭表示不區(qū)分大小寫的正則匹配
更多詳細(xì)localtion的正則匹配規(guī)則可參考:nginx配置location總結(jié)及rewrite規(guī)則寫法
后記
筆者也是Nginx的初級使用者,希望通過通俗易懂的方式記錄這些知識,分享給有需要的人,一起鉆研學(xué)習(xí),如有紕漏,歡迎指正,謝謝!
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對創(chuàng)新互聯(lián)的支持。