亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

nginx部署/代理/跨域

int64 / 3572人閱讀

摘要:關(guān)于咱們先了解在開發(fā)過程中的主要作用解決跨域負載均衡一解決跨域如果要理解什么是跨域廣義上的跨域是指一個域下的文檔或腳本試圖去請求另一個域下的資源。標記為備份服務(wù)器。當主服務(wù)器不可用時,將傳遞與備份服務(wù)器的連接。

關(guān)于nginx,咱們先了解nginx在開發(fā)過程中的主要作用

nginx解決跨域

nginx負載均衡

一、nginx解決跨域

如果要理解什么是跨域

廣義上的跨域是指一個域下的文檔或腳本試圖去請求另一個域下的資源。即瀏覽器的同源策略/SOP限制引起的跨域也屬于在內(nèi);

那么什么是同源策略呢?

同源策略/SOP(Same origin policy)是一種約定,由Netscape公司1995年引入瀏覽器,它是瀏覽器最核心也最基本的安全功能,如果缺少了同源策略,瀏覽器很容易受到XSS、CSFR等攻擊。同源策略即: 協(xié)議+域名+端口"三者相同

常見的跨域場景如下:

         URL                                      說明                         是否允許通信

    http://www.baidu.com/hello.js
    http://www.baidu.com/world.js         同一域名,不同文件或路徑           允許(無跨域)
    http://www.baidu.com/hello/world.js


    http://www.baidu.com:8000/hello.js
    http://www.baidu.com/hello.js         同一域名,不同端口                不允許(有跨域)

    http://www.baidu.com/hello.js
    https://www.baidu.com/world.js        同一域名,不同協(xié)議                不允許(有跨域)

    http://www.baidu.com/hello.js
    http://192.168.22.128/world.js        域名和域名對應(yīng)ip                 不允許(有跨域)

    http://baidu.com/hello.js
    http://x.baidu.com/hello.js           主域相同,子域不同                不允許(有跨域)
    http://www.baidu.com/hello.js

    http://www.baidu.com/hello.js
    http://www.bai.com/world.js           不同域名                        不允許(有跨域)
常見的跨域解決方案有如下:
1. jsonp解決跨域
2. document.domain + iframe解決跨域
3.  nginx代理解決跨域
4.  nodejs中間件代理解決跨域
重點來了 nginx代理解決跨域;
server {
          listen       80;
          server_name  localhost; //前端域名 具體原理解釋在下方

          location / {  // location / 代理所有請求 而如果是 location /api 則匹配到有/api 前綴的請求才會代理
                  proxy_pass www.baidu.com; // 服務(wù)端域名
          }
  }

前端server域名是localhost

服務(wù)器server域名是www.baidu.com

根據(jù)瀏覽器的SOP/同源策略 localhost對www.baidu.com發(fā)起請求一定會出現(xiàn)跨域問題;但現(xiàn)在只要我們啟動nginx服務(wù)器把server_name設(shè)置成前端的域名,
此時前端發(fā)起的請求相當于是localhost對localhost發(fā)起,這樣是不會引起跨域的;但真實情況是,nginx對localhost的請求代理回 www.baidu.com

這里贅述一下什么是代理;

代理是在服務(wù)器和客戶端之間假設(shè)的一層服務(wù)器(中間服務(wù)器),代理將接收客戶端的請求并將它轉(zhuǎn)發(fā)給服務(wù)器,然后將服務(wù)端的響應(yīng)轉(zhuǎn)發(fā)給客戶端。
代理分為正向代理和反向代理:具體區(qū)別自行百度...
二、nginx負載均衡

nginx是通過把請求分發(fā)到服務(wù)器列表來實現(xiàn)負載均衡的;具體實現(xiàn)如下:

          upstream balance.com{
                         server 192.168.2.100:42000;
                         server 192.168.2.101:42000;
                         server 192.168.2.102:42000;
            }



            server {
                    server_name  fe.server.com;
                    listen 80;
                    location /api {
                            proxy_pass http://balance.com;
                    }
            }

上面的配置只是指定了nginx需要轉(zhuǎn)發(fā)的服務(wù)端列表,并沒有指定分配策略。

nginx負載均衡策略

1.輪詢策略

> 輪詢策略是默認的策略,把每個請求按順序逐一分配到不同的server,如果server掛掉,能自動剔除
    upstream balance.com{
            server 192.168.2.100:42000;
            server 192.168.2.101:42000;
            server 192.168.2.102:42000;
        }

2.最少連接數(shù)策略

把請求優(yōu)先分配給連接數(shù)最少的server,可以平衡每個隊列的長度;
    upstream balance.com{
            least_conn;
            server 192.168.2.100:42000;
            server 192.168.2.101:42000;
            server 192.168.2.102:42000;
        }

3.最快響應(yīng)時間策略

優(yōu)先分配給響應(yīng)時間最短的服務(wù)器。
  upstream balance.com {
     fair;
    server 192.168.2.100:42000;
    server 192.168.2.101:42000;
    server 192.168.2.102:42000;
 }

4.權(quán)重策略

使用weight來指定server訪問比率,weight默認是1。訪問率比例等于權(quán)重比例;
    upstream balance.com{
             server 192.168.2.100:42000 weight=1;
             server 192.168.2.101:42000 weight=2;
             server 192.168.2.102:42000 weight=3;
        }

5.客戶端ip綁定 ip_hash

每個請求會按照訪問ip的hash值分配,這樣同一客戶端連續(xù)的Web請求都會被分發(fā)到同一server進行處理,可以解決session的問題。如果server掛掉,能自動剔除。
    upstream balance.com{
        ip_hash;
        server 192.168.2.100:42000 weight=1;
        server 192.168.2.101:42000 weight=2;
        server 192.168.2.102:42000 weight=3;
    }

backup 標記為備份服務(wù)器。當主服務(wù)器不可用時,將傳遞與備份服務(wù)器的連接。

    upstream balance.com{
        server 192.168.2.100:42000 backup;
        server 192.168.2.101:42000;
    }
本文介紹的是基礎(chǔ)功能,如果想了解更多請轉(zhuǎn)nginx文檔

以上是博主目前了解和使用到的一些技巧和知識啦,至于關(guān)于nginx部署后404問題請看@安靜Eno| vue框架下部署上線后刷新報404問題解決方案

尊重原著 文章轉(zhuǎn)自@安靜Enonginx部署/代理/跨域

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://www.ezyhdfw.cn/yun/40446.html

相關(guān)文章

  • 通過nginx反向代理解決前端訪問的跨域問題

    摘要:三反向代理解決的原理將安裝在本地,然后將項目部署于下,這樣訪問本地項目時用本地項目即可訪問。這樣瀏覽器之間的請求完全滿足瀏覽器域名協(xié)議端口相同的同源策略,可在不改變后臺接口的情況下避免跨域問題。 一、問題背景說明: 編寫移動前端頁面時需要訪問后臺系統(tǒng)接口。前端項目在本地(個人辦公電腦)開發(fā),后臺接口存放后生產(chǎn)的后臺服務(wù)器,本地的ajax請求無法直接訪問后臺接口,也就是遇到了跨域問題...

    dongxiawu 評論0 收藏0
  • 通過nginx反向代理解決前端訪問的跨域問題

    摘要:三反向代理解決的原理將安裝在本地,然后將項目部署于下,這樣訪問本地項目時用本地項目即可訪問。這樣瀏覽器之間的請求完全滿足瀏覽器域名協(xié)議端口相同的同源策略,可在不改變后臺接口的情況下避免跨域問題。 一、問題背景說明: 編寫移動前端頁面時需要訪問后臺系統(tǒng)接口。前端項目在本地(個人辦公電腦)開發(fā),后臺接口存放后生產(chǎn)的后臺服務(wù)器,本地的ajax請求無法直接訪問后臺接口,也就是遇到了跨域問題...

    paulquei 評論0 收藏0
  • Nginx

    摘要:此外,其也能夠提供強大的反向代理功能。是由為俄羅斯訪問量第二的站點開發(fā)的,第一個公開版本發(fā)布于年月日。 keepalived+nginx 實現(xiàn)高可用雙機熱備 + 負載均衡架構(gòu) 1 準備4個ubuntu16.04虛擬機(啟用網(wǎng)卡二并使用橋接模式):A服務(wù)器:192.168.0.103 主B服務(wù)器:192.168.0.104 主(備) 前端工程師學(xué)習(xí) Nginx ...

    syoya 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<