首頁 >運維 >Nginx >怎麼利用Nginx反向代理與負載平衡搭建多人測試環境

怎麼利用Nginx反向代理與負載平衡搭建多人測試環境

PHPz
PHPz轉載
2023-05-23 17:29:471241瀏覽

實作原則

當我們造訪一個網站,請求頭中會有user-agent 的頭部,如mozilla/5.0 (macintosh; intel mac os x 10.12; rv: 50.0) gecko/20100101 firefox/50.0,這個ua 是可以自訂的,許多瀏覽器外掛程式也支援新增自訂ua,如火狐的user agent swicher 外掛程式。

怎麼利用Nginx反向代理與負載平衡搭建多人測試環境

如圖,這裡新增了一個自訂ua,內容改成了自己的名字,透過這個ua 請求網站,我們可以在請求頭中看到ua變成自己的了,這就是一個標識。

根據這個 ua ,透過 nginx 進行判斷,不同的 ua 轉發到不同的端口,每個端口下對應一個網站目錄。

nginx 判斷 ua

透過 nginx 可以取得每次請求的 ua,即 $http_user_agent 變數。

如在 location 域中可以這樣判斷 ua 並設定一個標識:

if ( $http_user_agent ~ "dashen" ) {
 set $flag "01";
}

例如判斷 ua 內容為 dashen,設定 $flag 為 01,可以設定很多這樣的識別。

nginx 反向代理與負載平衡

透過判斷不同的ua,我們可以透過反向代理轉送到不同的機器和端口,這裡同一台測試機可以轉送到本機的不同的端口,監聽不同的端口設定不同的網站目錄。

具體如下:

server
{
 listen 192.168.1.251:80;
 server_name *.example.com;
 index index.html index.htm index.php;
 charset utf-8;
 location / {
 set $flag "00";
 if ( $http_user_agent ~ "dashen" ) {
   set $flag "01";
  }
 if ( $http_user_agent ~ "mianwo" ) {
   set $flag "02";
  }
 if ( $http_user_agent ~ "bingkuai" ) {
   set $flag "03";
  }
 if ( $http_user_agent ~ "hadoop" ) {
   set $flag "04";
  }
  proxy_set_header host $host;
  proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for;
  if ( $flag = "00" ){
   add_header z-server mobile;
   proxy_pass http://webserver_mobile;
  }
  if ( $flag = "01" ){
   add_header z-server dashen;
   proxy_pass http://webserver_dashen;
  }
  if ( $flag = "02" ){
   add_header z-server mianwo;
   proxy_pass http://webserver_mianwo;
  }
  if ( $flag = "03" ){
   add_header z-server bingkuai;
   proxy_pass http://webserver_bingkuai;
  }
  if ( $flag = "04" ){
   add_header z-server hadoop;
   proxy_pass http://webserver_hadoop;
  }
 }
}

這段配置將不同的 ua 請求反向代理到不同的負載平衡伺服器,下面看具體的負載平衡配置。

nginx 負載平衡配置

這裡定義了幾個負載平衡配置,每個負載平衡配置其實只配了一台機器,也就是本機的不同端口。

upstream webserver_mobile{
 server 127.0.0.1:8900 max_fails=2 weight=2 fail_timeout=10s;
}
upstream webserver_dashen{
 server 127.0.0.1:8901 max_fails=2 weight=2 fail_timeout=10s;
}
upstream webserver_mianwo{
 server 127.0.0.1:8902 max_fails=2 weight=2 fail_timeout=10s;
}
upstream webserver_bingkuai{
 server 127.0.0.1:8903 max_fails=2 weight=2 fail_timeout=10s;
}
upstream webserver_hadoop{
 server 127.0.0.1:8904 max_fails=2 weight=2 fail_timeout=10s;
}

那麼,還沒結束,接下來需要做的是,像一個正常的網站那樣去配置多個nginx 虛擬主機,不同的是這裡需要監聽幾個不同的端口,就需要幾個虛擬主機配置,只是網站的目錄不同,如ua 是dashen ,對應網站目錄是/vhosts/example.com/dashen,如ua 是mianwo,對應的網站目錄是/vhosts/example.com/mianwo.

這樣一來,不同的測試人員,在對應自己ua 的網站目錄下拉取分支,透過瀏覽器插件配置自己的ua,就實現了多人同時在一台機器上拉取不同的分支,而且造訪同樣的域名,根據ua 不同實現網站根目錄分開,而且互不影響。

以上是怎麼利用Nginx反向代理與負載平衡搭建多人測試環境的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除