av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

如何使用Weave以及Docker搭建Nginx反向代理/負載均衡服務器

如何使用Weave以及docker搭建Nginx反向代理/負載均衡服務器

作者:Arun Pyasi 2015-09-06 09:53:41

云計算

系統(tǒng)運維 在這篇教程里,我們將使用 nginx 來將負載均衡分配到一個運行 Apache 的容器集合。最簡單輕松的方法就是使用 Weave 來把運行在 ubuntu 上的 docker 容器中的 nginx 配置成負載均衡服務器。

網站建設哪家好,找創(chuàng)新互聯(lián)公司!專注于網頁設計、網站建設、微信開發(fā)、小程序開發(fā)、集團企業(yè)網站建設等服務項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了萍鄉(xiāng)免費建站歡迎大家使用!

Hi, 今天我們將會學習如何使用 Weave 和 Docker 搭建 Nginx 的反向代理/負載均衡服務器。Weave 可以創(chuàng)建一個虛擬網絡將 Docker 容器彼此連接在一起,支持跨主機部署及自動發(fā)現(xiàn)。它可以讓我們更加專注于應用的開發(fā),而不是基礎架構。Weave 提供了一個如此棒的環(huán)境,仿佛它的所有容器都屬于同個網絡,不需要端口/映射/連接等的配置。容器中的應用提供的服務在 weave 網絡中可以輕易地被外部世界訪問,不論你的容器運行在哪里。在這個教程里我們將會使用 weave 快速并且簡單地將 nginx web 服務器部署為一個負載均衡器,反向代理一個運行在 Amazon Web Services 里面多個節(jié)點上的 docker 容器中的簡單 php 應用。這里我們將會介紹 WeaveDNS,它提供一個不需要改變代碼就可以讓容器利用主機名找到的簡單方式,并且能夠讓其他容器通過主機名連接彼此。

在這篇教程里,我們將使用 nginx 來將負載均衡分配到一個運行 Apache 的容器集合。最簡單輕松的方法就是使用 Weave 來把運行在 ubuntu 上的 docker 容器中的 nginx 配置成負載均衡服務器。

1. 搭建 AWS 實例

首先,我們需要搭建 Amzaon Web Service 實例,這樣才能在 ubuntu 下用 weave 跑 docker 容器。我們將會使用AWS 命令行 來搭建和配置兩個 AWS EC2 實例。在這里,我們使用最小的可用實例,t1.micro。我們需要一個有效的Amazon Web Services 賬戶使用 AWS 命令行界面來搭建和配置。我們先在 AWS 命令行界面下使用下面的命令將 github 上的 weave 倉庫克隆下來。

  
 
 
  1. $ git clone https://github.com/weaveworks/guides
  2. $ cd weave-gs/aws-nginx-ubuntu-simple

在克隆完倉庫之后,我們執(zhí)行下面的腳本,這個腳本將會部署兩個 t1.micro 實例,每個實例中都是 ubuntu 作為操作系統(tǒng)并用 weave 跑著 docker 容器。

  
 
 
  1. $ sudo ./demo-aws-setup.sh

在這里,我們將會在以后用到這些實例的 IP 地址。這些地址儲存在一個 weavedemo.env 文件中,這個文件創(chuàng)建于執(zhí)行 demo-aws-setup.sh 腳本期間。為了獲取這些 IP 地址,我們需要執(zhí)行下面的命令,命令輸出類似下面的信息。

  
 
 
  1. $ cat weavedemo.env
  2.  
  3. export WEAVE_AWS_DEMO_HOST1=52.26.175.175
  4. export WEAVE_AWS_DEMO_HOST2=52.26.83.141
  5. export WEAVE_AWS_DEMO_HOSTCOUNT=2
  6. export WEAVE_AWS_DEMO_HOSTS=(52.26.175.175 52.26.83.141)

請注意這些不是固定的 IP 地址,AWS 會為我們的實例動態(tài)地分配 IP 地址。

我們在 bash 下執(zhí)行下面的命令使環(huán)境變量生效。

  
 
 
  1. . ./weavedemo.env

 

2. 啟動 Weave 和 WeaveDNS

在安裝完實例之后,我們將會在每臺主機上啟動 weave 以及 weavedns。Weave 以及 weavedns 使得我們能夠輕易地將容器部署到一個全新的基礎架構以及配置中, 不需要改變代碼,也不需要去理解像 Ambassador 容器以及 Link 機制之類的概念。下面是在第一臺主機上啟動 weave 以及 weavedns 的命令。

  
 
 
  1. ssh -i weavedemo-key.pem ubuntu@$WEAVE_AWS_DEMO_HOST1
  2. $ sudo weave launch
  3. $ sudo weave launch-dns 10.2.1.1/24

下一步,我也準備在第二臺主機上啟動 weave 以及 weavedns。

  
 
 
  1. ssh -i weavedemo-key.pem ubuntu@$WEAVE_AWS_DEMO_HOST2
  2. $ sudo weave launch $WEAVE_AWS_DEMO_HOST1
  3. $ sudo weave launch-dns 10.2.1.2/24

 

3. 啟動應用容器

現(xiàn)在,我們準備跨兩臺主機啟動六個容器,這兩臺主機都用 Apache2 Web 服務實例跑著簡單的 php 網站。為了在第一個 Apache2 Web 服務器實例跑三個容器, 我們將會使用下面的命令。

  
 
 
  1. ssh -i weavedemo-key.pem ubuntu@$WEAVE_AWS_DEMO_HOST1
  2. $ sudo weave run --with-dns 10.3.1.1/24 -h ws1.weave.local fintanr/weave-gs-nginx-apache
  3. $ sudo weave run --with-dns 10.3.1.2/24 -h ws2.weave.local fintanr/weave-gs-nginx-apache
  4. $ sudo weave run --with-dns 10.3.1.3/24 -h ws3.weave.local fintanr/weave-gs-nginx-apache

在那之后,我們將會在第二個實例上啟動另外三個容器,請使用下面的命令。

  
 
 
  1. ssh -i weavedemo-key.pem ubuntu@$WEAVE_AWS_DEMO_HOST2
  2. $ sudo weave run --with-dns 10.3.1.4/24 -h ws4.weave.local fintanr/weave-gs-nginx-apache
  3. $ sudo weave run --with-dns 10.3.1.5/24 -h ws5.weave.local fintanr/weave-gs-nginx-apache
  4. $ sudo weave run --with-dns 10.3.1.6/24 -h ws6.weave.local fintanr/weave-gs-nginx-apache

注意: 在這里,--with-dns 選項告訴容器使用 weavedns 來解析主機名,-h x.weave.local 則使得 weavedns 能夠解析該主機。

4. 啟動 Nginx 容器

在應用容器如預期的運行后,我們將會啟動 nginx 容器,它將會在六個應用容器服務之間輪詢并提供反向代理或者負載均衡。 為了啟動 nginx 容器,請使用下面的命令。

  
 
 
  1. ssh -i weavedemo-key.pem ubuntu@$WEAVE_AWS_DEMO_HOST1
  2. $ sudo weave run --with-dns 10.3.1.7/24 -ti -h nginx.weave.local -d -p 80:80 fintanr/weave-gs-nginx-simple

因此,我們的 nginx 容器在 $WEAVEAWSDEMO_HOST1 上公開地暴露成為一個 http 服務器。

5. 測試負載均衡服務器

為了測試我們的負載均衡服務器是否可以工作,我們執(zhí)行一段可以發(fā)送 http 請求給 nginx 容器的腳本。我們將會發(fā)送6個請求,這樣我們就能看到 nginx 在一次的輪詢中服務于每臺 web 服務器之間。

  
 
 
  1. $ ./access-aws-hosts.sh
  2.  
  3. {
  4. "message" : "Hello Weave - nginx example",
  5. "hostname" : "ws1.weave.local",
  6. "date" : "2015-06-26 12:24:23"
  7. }
  8. {
  9. "message" : "Hello Weave - nginx example",
  10. "hostname" : "ws2.weave.local",
  11. "date" : "2015-06-26 12:24:23"
  12. }
  13. {
  14. "message" : "Hello Weave - nginx example",
  15. "hostname" : "ws3.weave.local",
  16. "date" : "2015-06-26 12:24:23"
  17. }
  18. {
  19. "message" : "Hello Weave - nginx example",
  20. "hostname" : "ws4.weave.local",
  21. "date" : "2015-06-26 12:24:23"
  22. }
  23. {
  24. "message" : "Hello Weave - nginx example",
  25. "hostname" : "ws5.weave.local",
  26. "date" : "2015-06-26 12:24:23"
  27. }
  28. {
  29. "message" : "Hello Weave - nginx example",
  30. "hostname" : "ws6.weave.local",
  31. "date" : "2015-06-26 12:24:23"
  32. }

 

結束語

我們最終成功地將 nginx 配置成一個反向代理/負載均衡服務器,通過使用 weave 以及運行在 AWS(Amazon Web Service)EC2 里面的 ubuntu 服務器中的 docker。從上面的步驟輸出可以清楚的看到我們已經成功地配置了 nginx。我們可以看到請求在一次輪詢中被發(fā)送到6個應用容器,這些容器在 Apache2 Web 服務器中跑著 PHP 應用。在這里,我們部署了一個容器化的 PHP 應用,使用 nginx 橫跨多臺在 AWS EC2 上的主機而不需要改變代碼,利用 weavedns 使得每個容器連接在一起,只需要主機名就夠了,眼前的這些便捷, 都要歸功于 weave 以及 weavedns。

如果你有任何的問題、建議、反饋,請在評論中注明,這樣我們才能夠做得更好,謝謝:-)


via: http://linoxide.com/linux-how-to/nginx-load-balancer-weave-docker/

作者:Arun Pyasi 譯者:dingdongnigetou 校對:wxy


文章題目:如何使用Weave以及Docker搭建Nginx反向代理/負載均衡服務器
URL地址:http://uogjgqi.cn/article/djipsso.html
掃二維碼與項目經理溝通

我們在微信上24小時期待你的聲音

解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯(lián)網交流