成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

深入Cloud Foundry(下)

qylost / 1436人閱讀
續(xù)與回顧

本文第一部分介紹了CloudFoundry的整體架構(gòu),并在最后花了一點篇幅簡介CloudFoundry的代碼組織情況,以便于讀者自己去研究源代碼。筆者認為開源項目較大的好處在于:當你讀懂源代碼、理解總體架構(gòu)后,能夠成竹在胸,并吸收為己用(有點類似武俠小說中的“北冥神功”)?!盀榧河谩本褪潜酒f的內(nèi)容:我們使用CloudFoundry搭建自己的私有PaaS平臺。

在介紹CloudFoundry之前,先說明一下,VMware在企業(yè)云應用平臺的產(chǎn)品線上,有另外一款產(chǎn)品,叫做VMwarevFabric Cloud Application Platfor[1],這和Cloud Foundry屬于兩個產(chǎn)品,分別由兩批團隊開發(fā)。相比較來說,選擇vFabric會更令人省心省力,畢竟作為商業(yè)產(chǎn)品,完善很多,而且發(fā)展已久,和STS[2]深度整合。如果企業(yè)以應用為目的,不希望開發(fā)上面耗費太多人力物力,不妨考慮一下;如果選擇Hard模式,打算以CloudFoundry為基礎(chǔ)搭建私有云,那就開始吧!

第二部份 基于CloudFoundry的私有云實踐?

?一、安裝配置CloudFoundry

本文內(nèi)容所提到的CloudFoundry版本較早,,所以不可能一直緊跟著CloudFoundry的更新,造成有些內(nèi)容并不是針對代碼庫,雖然我會比較新代碼庫來寫這篇文章,但是請一定不要把本文當作按部就班的安裝說明書。

去年10月份開始,CloudFoundry的主代碼vcap里面新增加了個目錄叫做dev_setup,Cloud Foundry大方地公開了他們的部署代碼,這樣大大簡化了我們把CloudFoundry部署在自建數(shù)據(jù)中心的難度。如之前Figo在VMwareCloud Forum提到的一樣,CloudFoundry官方用Chef[3]作為部署工具 。Chef是OrchestrationEngine的一種,可以自動化管理、部署復雜的云環(huán)境。工作過程大概就是我們需要寫一系列的“recipes”,這些“recipes”描述我們需要把我們的服務(wù)器部署成什么(Apache,MySQL還是Hadoop?),然后Chef可以自己執(zhí)行這些配置?,F(xiàn)在數(shù)據(jù)中心變得越來越龐大,原來那種通過自己寫腳本完成自動部署的IT管理方式日漸不堪重負,幫助管理、部署數(shù)據(jù)中心服務(wù)器集群的中間件變得越來越重要,我們統(tǒng)稱這類型工具為OrchestrationEngine.

回到正題,如果使用了新版的CloudFoundry,可以參考dev_setup目錄和dev_setup/deployments目錄下面的兩個README文件。基本上使用提供的腳本來部署不同的CloudFoundry組件就是一條命令的事情。

但是既然我們命題為深入CloudFoundry,那就必須深入地了解整個CloudFoundry的部署過程。 在這之前讓我們先回顧第一部分里面的CloudFoundry總體架構(gòu)圖:


深入Cloud Foundry(下)
Figure 1 CloudFoundry 總體架構(gòu)圖

從圖1中可以看出兩點:

1、? CloudFoundry是完全模塊化的設(shè)計,每個模塊多帶帶存在、運轉(zhuǎn)。CloudFoundry是基于Ruby開發(fā)的,那每個部分可以認為拿來即可運行,不存在編譯等過程;

2、? 我們需要配置換的應該是圖中的箭頭部分。換句話說就是如何把每個模塊連接起來,使其成為一個完整的、分布式的系統(tǒng)。這點就是我們現(xiàn)在要做的事情。

如果你是用:

深入Cloud Foundry(下)
?

安裝的CloudFoundry,那你的系統(tǒng)里面就應該包含了所有的子模塊。

?

DEA, Health_Manager, Router這三個模塊,代碼結(jié)構(gòu)比較接近:都有一個bin目錄,毫無疑問里面就是可執(zhí)行文件,但是打開著個文件會發(fā)現(xiàn)它只是個簡單的link,真正的執(zhí)行文件在lib下面,有對應的rb文件;而這幾個模塊的根目錄下面都有一個config目錄,里面有以模塊命名的yml文件,這就是他們的配置文件。

而cloud_controller模塊,之前已經(jīng)說過它是個典型的RoR項目,里面的文件結(jié)構(gòu)有點復雜,文件有點多,但是還是能找到config/cloud_controller.yml這個文件的;

?

接著就是service模塊,這里會看到很多似曾相識的子目錄,比如mysql,Redis, rabbit, mongodb。專業(yè)人士一看就知道是不同的服務(wù),每個服務(wù)一個文件夾,點進這些目錄看,又看到熟悉的結(jié)構(gòu)了,比如bin,config, lib,很簡單,和前面的DEA,Router等模塊的結(jié)構(gòu)一樣。但是打開bin后,發(fā)現(xiàn)執(zhí)行文件有點多,有個gateway,還有個node。(如果你是新的代碼庫,可能還看到個backup,顧名思義就是配置service備份工作的,不難理解,這里就不敘述了)

?

我們來聊聊Service模塊的gateway和node。Gateway在一個servicenode里面負責處理restfulapi的相關(guān)事情,負責讀入并初始化messagebus。Node是service的具體執(zhí)行者,包括響應message,與底層service的交互等等。但是從配置文件來說,因為gateway負責解析初始化messagebus,所以與messagebus相關(guān)的配置信息反而放在了xxx_gateway.yml里面;而xxx_node.yml則是一些關(guān)于底層配置的信息,拿mysql_node.yml來說,就是一些max_long_query,max_long_tx這些信息。

?

如果我們要架構(gòu)分布式的云環(huán)境,不應該選擇在一臺服務(wù)器里面安裝所有的模塊,下面簡單介紹下做法:

?

通過研究源代碼,我們知道CloudFoundry的主安裝文件vcap_setup里是可以選擇安裝哪些組件的。所以安裝全部組件應該是install這個腳本搞的鬼,我們?nèi)タ纯磇nstall[4]里面做了什么?

?

通過略讀install腳本,發(fā)現(xiàn)它不難理解,且每一個步驟都有一個echo來說明。它分別做了以下動作:

1、? 檢測是否是Linux或者MacOS環(huán)境;

2、? 安裝依賴包;

3、? 安裝并啟動RVM;

4、? 安裝Ruby;

5、? 下載vcap;

6、? 安裝配置vcap;

7、? 重啟Nginx;

8、? 安裝Bundler。

?

其中注意這一行命令:

深入Cloud Foundry(下)

這里面的參數(shù)–a與-s。在vcap_setup的comments里面有如下定義,

深入Cloud Foundry(下)
?

?

也就是說,install腳本為了省去安裝時的提問過程,剝奪了我們的自主選擇權(quán)!那么解決方法就簡單了——把這句改了,然后執(zhí)行install,我們應該能看到安裝腳本詢問要不要安裝Router?要不要安裝CloudController?同樣的,因為去掉了-s參數(shù),所以在安裝過程中會提示需要安裝的Service類型。

下面是我們實驗室中服務(wù)器的具體配置圖,

?

深入Cloud Foundry(下)

Figure 2 Cloud Foundry 在ELC 實驗室中的部署圖

?

首先,我們手上沒有硬件LoadBalancer,而且為了節(jié)約ip資源,我們決定只用一個外部ip,使用橋接,然后用Ngnix來做loadbalancer,所有的requests會轉(zhuǎn)向4臺Router。

?

我建議Router宜多一點,因為CloudFoundry當前的設(shè)計,Router的資源會很緊張,但是如第一部分說到那樣,這問題會在以后的版本改善。目前還是多加點Router服務(wù)器吧。

?

然后CloudController我們用了3臺,并且這三臺也同時兼了Health_Manager的功能,因為CloudController主管的是控制流,資源占用不會太大。我一開始也覺得CloudController會很耗資源,因為從上一部分的工作描述來看,它負責的工作還是比較多的,但實際應用下來,結(jié)果和筆者想的相差很遠。這部分需要的資源其實并不多,可能因為我們不是經(jīng)常需要啟動/關(guān)閉/刪除instance。

?

后面是一個多帶帶的數(shù)據(jù)庫服務(wù)器。在生產(chǎn)環(huán)境里用的是PostgreSQL,用其他也是可以的,在cloud_controller.yml里面修改就好。這是整套系統(tǒng)的單點,我也一度擔心過,但據(jù)說CloudFoundry.com用的也是單點數(shù)據(jù)庫,沒存在太大問題。據(jù)說CloudFoundry在設(shè)計的時候已經(jīng)注意到這里的數(shù)據(jù)流量問題。

?

接著是5臺服務(wù)器用于Health-Manger,其中3臺與CloudController公用。因為我希望多檢測一點數(shù)據(jù),用于后面的管理,所以在這里狠下了心。

?

DEA模塊,也是5臺服務(wù)器。這里算是app的主場,建議根據(jù)資源需求動態(tài)增加,CloudFoundry有很好的擴展性設(shè)計,如果某一模塊吃不消了,都可以動態(tài)添加。

?

Service模塊,同樣給了5臺。我們目前只用到Mysql,Postgresql和MongoDB。同樣按照項目需要來加。其他Service暫時還沒用上。

?

接著就是貫穿這套系統(tǒng)的MessageBus模塊。CloudFoundry的所有模塊都需要指定到這個MessageBus。它是基于NATS的,輕量級,很好用,但是有個問題是不支持HA/HP集群,也就是說無法配成多臺Messagebus hosts。這部份據(jù)說正在開發(fā),而既然CloudFoundry.com都能應付得了,我們私有云,一臺server,應該足矣!

?

后面我們選幾個模塊看看具體的配置修改:

1. /etc/nginx/nginx.conf

前面說到,我們用一臺nginx來作為loadbalancer。我們整個服務(wù)器集群用的是虛擬機,這臺虛擬機配雙網(wǎng)卡,分別設(shè)為privatenetwork和vmnetwork,兩網(wǎng)卡間采用橋接。這臺服務(wù)器有雙ip:10.32.105.165和192.168.1.178。我們進入這臺機器,選擇Nginx的一個原因是,只要安裝CloudFoundry,因為Router組件是基于Nginx的,所以都會安裝這個HttpServer,減少了我的工作。配置Nginx沒什么特殊之處,我用了最簡單的方法,設(shè)置一個upstream,采用RR來均衡負載。

?
深入Cloud Foundry(下)
然后設(shè)置location的proxy_pass到這個upstream:
?
深入Cloud Foundry(下)
?
Ngnix用作loadbalancer的做法很多,而且可以引入權(quán)重算法等,大家按需使用。
2. Router.yml

Load balancer出來的request就會流到Router組件,Router.yml的配置相當簡單:

?

深入Cloud Foundry(下)

需要改的只有mbus,就是把mbus指到我們的mbus服務(wù)器去。

3. cloud_controller.yml

Cloud_controller.yml看起來相當復雜,我們可以選擇需要的配置修改:

深入Cloud Foundry(下)
?
這三行屬于api的URI信息。external_uri比較重要,請在DNS里面綁定這個域名到LoadBalancer的外部ip地址(如果沒有的話,需要訪問的client要配置hosts文件,綁定LoadBalancer和這個域名)。我們的配置是在DNS綁定好api.elc.com和10.32.105.165。

深入Cloud Foundry(下)
?

按照配置文件里面的介紹,說這個可以不修改,默認為nil,我配置成了CloudController的ServerIp,用起來沒出問題。

?

接著有兩個重要的配置:

深入Cloud Foundry(下)
?

這兩個目錄是關(guān)于用戶上傳的apps(在Cloud Foundry里叫做Droplets),以及相關(guān)資源的目錄。上一部分說到,在CloudController的當前實現(xiàn),是采用一個NFS來存儲這些Droplets,使它全局。所以我們在此之前,需要建立一個NFS,并且每個安裝Cloud_Controller的服務(wù)器把這個NFSmount到/var/vcap/shared下。這點非常非常重要,否則會出現(xiàn)上文說的啟動失敗問題!

?

接下去,我們需要配一個,所有CloudFoundry組件都要配置的內(nèi)容,mbus:

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

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

相關(guān)文章

  • PaaS未來世界

    摘要:未來世界此屏幕截圖是一個非常好的例子,它包含了通過或者命令行開始所需要的所有內(nèi)容。未來世界架構(gòu)元素核心系統(tǒng)架構(gòu)系統(tǒng)的核心和的附加功能都圍繞著控制器。而健康管理器的作用是識別任何可能產(chǎn)生的問題,并通過告知控制器或者其他機制來解決這些問題。 PaaS的未來會是什么樣的呢?NoOps和DevOps又如何融入其中呢?PaaS將會讓開發(fā)者生活的更加輕松。 實際上,PaaS是一些事物的混合體,它關(guān)注更快...

    Lavender 評論0 收藏0
  • 基于Cloud Foundry的PaaS開發(fā)與部署

    摘要:基于的實踐一綜述參見還可參見基于的實踐之集群部署單結(jié)點的部署由于提供的安裝腳本,使用簡單不再陳述,大家參照一下官網(wǎng)即可,在此主要談?wù)劧嘟Y(jié)點集群部署的要點。關(guān)于,大家可參考和。 使用Cloud foundry(以下簡稱CF)接近一年時間,一直缺少時間寫些東西與大家探討。最近,打算寫一下。目前使用經(jīng)歷主要包括:  1. 搭建CF運行環(huán)境并維護;  2. 部分代碼修改和新功能擴充的工作;  3. ...

    chinafgj 評論0 收藏0
  • 一招鮮吃遍天,做好混合云,這招管用

    摘要:俗語有一招鮮,吃遍天。其中,的企業(yè)正在實施多云戰(zhàn)略,的企業(yè)采用混合云戰(zhàn)略,將公有云和私有云集成在一起。隨著混合云的五個一體化由戴爾易安信在戴爾科技峰會上對外發(fā)布,其混合云的新利器也正式登臺亮相了。俗語有一招鮮,吃遍天。說的是行走江湖須得有一技之長,方能到處謀生,不會餓了肚子。時過境遷,這句話放在今天依然有效。隨著IT環(huán)境正向混合云以及多云邁進,這一過程有沒有一招鮮的方法呢?讓客戶省時省力又省...

    iOS122 評論0 收藏0
  • 深入 Cloud Foundry(上)

    引子 今年4月份,VMware突然發(fā)布了業(yè)內(nèi)第一個開源的PaaS——CloudFoundry。幾個關(guān)鍵字:開源、PaaS、VMware,如果你對云計算感興趣,就沖著它的ApacheV2協(xié)議,如果不去GitHub拿它的代碼好好研讀一下,真有點對不起自己。筆者當時就是以這樣的心態(tài)去研究它的代碼,并把它部署在我們labs里面。發(fā)布至今的這幾個月里,筆者一直關(guān)注它的演進,并從它的架構(gòu)設(shè)計中獲益良多,...

    XiNGRZ 評論0 收藏0
  • IBM Bluemix開啟云開發(fā)時代

    摘要:運行時環(huán)境,又叫構(gòu)建包上提供的一系列運行時環(huán)境包括圖中顯示的七種命名構(gòu)建包,外加已批準用于的其他任何構(gòu)建包。開發(fā)運營服務(wù)上的八種開發(fā)運營服務(wù)包括來自的五種服務(wù)和來自第三方的三種服務(wù)。 去年夏天我測評了Cloud Foundry PaaS(平臺即服務(wù)),當時著眼于Pivotal和ActiveState這兩種解決開源方案。這回測試時,我將關(guān)注IBM Bluemix,這是在SoftLayer上托管...

    cocopeak 評論0 收藏0

發(fā)表評論

0條評論

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