在平時的工做中,老是會遇到代理的概念。以前我只知道有代理這個概念,不過對其沒有一個清晰的理解。因而帶着如下兩個問題開始學習正向代理以及反向代理。html
首先附上一張說明圖,先有一個總體的理解。
前端
正向代理( Forward Proxy ):是指是一個位於客戶端和原始服務器之間的服務器,爲了從原始服務器取得內容, 客戶端向代理髮送一個請求並指定目標(原始服務器),而後代理向原始服務器轉交請求並將得到的內容返回給客戶端。客戶端才能使用正向代理。 web
反向代理( Reverse Proxy ):是指以代理服務器來接受 Internet 上的鏈接請求,而後將請求轉發給內部網絡上的服務器,並將從服務器上獲得的結果返回給 Internet 上請求鏈接的客戶端,此時代理服務器對外就表現爲一個反向代理服務器。segmentfault
Nginx 服務器的功能有不少,諸如反向代理、負載均衡、靜態資源服務器等。api
客戶端原本能夠直接經過 HTTP 協議訪問服務器,不過咱們能夠在中間加上一個 Nginx 服務器,客戶端請求 Nginx 服務器,Nginx 服務器請求應用服務器,而後將結果返回給客戶端,此時 Nginx 服務器就是反向代理服務器。跨域
# 虛擬主機的配置 server { listen 8080; # 監聽的端口 server_name 192.168.1.1; # 配置訪問域名 root /data/toor; # 站點根目錄 error_page 502 404 /page/404.html; # 錯誤頁面 location ^~ /api/ { # 使用 /api/ 代理 proxy_pass 的值 proxy_pass http://192.168.20.1:8080; # 被代理的應用服務器 HTTP 地址 } }
以上簡單的配置就能夠實現反向代理的功能。緩存
固然反向代理也能夠處理跨域問題,在 Vue 中就可使用 proxyTable
這個屬性進行相關的配置來解決跨域問題帶來的煩惱。配置以下:安全
... proxyTable: { '/weixin': { target: 'http://192.168.48.11:8100/', // 接口的域名 secure: false, // 若是是 https 接口,須要配置這個參數 changeOrigin: true, // 若是接口跨域,須要進行這個參數配置 pathRewrite: { '^/weixin': '' } }, }, ...
# upstream 表示負載服務器池,定義名字爲 my upstream my { server 192.168.2.1:8080 weight=1 max_fails=2 fail_timeout=30s; server 192.168.2.2:8080 weight=1 max_fails=2 fail_timeout=30s; server 192.168.2.3:8080 weight=1 max_fails=2 fail_timeout=30s; server 192.168.2.4:8080 weight=1 max_fails=2 fail_timeout=30s; # 即在 30s 內嘗試 2 次失敗即認爲主機不可用 }
負載均衡即將 請求/數據 輪詢分攤到多個服務器上執行,負載均衡的關鍵在於 均勻。服務器
也能夠經過 ip-hash
的方式,根據客戶端 ip 地址的 hash 值將請求分配給固定的某一個服務器處理。網絡
另外,服務器的硬件配置可能不一樣,配置好的服務器能夠處理更多的請求,這時能夠經過 weight
參數來控制。
以上。
本文是《前端詞典》系列的第一篇文章,這個系列會持續更新,每一期我都會講一個出現頻率較高的知識點。但願你們在閱讀的過程中能夠斧正文中出現不嚴謹或是錯誤的地方,本人將不勝感激;若經過本系列而有所得,本人亦將不勝欣喜。
內容: 前端以及網絡相關知識點的介紹並加以實際應用做爲輔助。
目的: 這個系列的文章能夠對讀者起到一點幫助,解開一些迷惑。
但願各位多指點一二,不吝賜教。