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

資訊專欄INFORMATION COLUMN

基于Cloud Foundry的PaaS開(kāi)發(fā)與部署

chinafgj / 3274人閱讀

摘要:基于的實(shí)踐一綜述參見(jiàn)還可參見(jiàn)基于的實(shí)踐之集群部署單結(jié)點(diǎn)的部署由于提供的安裝腳本,使用簡(jiǎn)單不再陳述,大家參照一下官網(wǎng)即可,在此主要談?wù)劧嘟Y(jié)點(diǎn)集群部署的要點(diǎn)。關(guān)于,大家可參考和。

使用Cloud foundry(以下簡(jiǎn)稱CF)接近一年時(shí)間,一直缺少時(shí)間寫(xiě)些東西與大家探討。最近,打算寫(xiě)一下。目前使用經(jīng)歷主要包括:

  1. 搭建CF運(yùn)行環(huán)境并維護(hù);

  2. 部分代碼修改和新功能擴(kuò)充的工作;

  3. 大量的應(yīng)用部署測(cè)試,主要是rails/Java兩類應(yīng)用;

  4. 支持新的Service嘗試;

  5. 其它待做事宜。。。


  由于CF是PAAS平臺(tái),這里面先介紹個(gè)人對(duì)paas的粗略理解。Paas, Platform as a Service, 其主要目的是提供一個(gè)應(yīng)用運(yùn)行的平臺(tái),有了這個(gè)平臺(tái),開(kāi)發(fā)者無(wú)需搭建應(yīng)用運(yùn)行環(huán)境和服務(wù)(MySQL/mongodb/Rabbitmq等),包括硬件和軟件(os/應(yīng)用軟件如tomcat/rails等)環(huán)境,開(kāi)發(fā)者可專注代碼開(kāi)發(fā),最終提供源碼(或war包之類的)信息,上傳至PAAS,即可運(yùn)行,并可創(chuàng)建DNS直接提供服務(wù),甚至可提供auto-scale,monitor,loadbalance等等運(yùn)行webservice需要的一切功能。


  簡(jiǎn)而言之,有了paas,開(kāi)發(fā)者只需要提供源碼,即可瞬間啟動(dòng)一個(gè)企業(yè)級(jí)的web service。


  Paas主要為server級(jí)的應(yīng)用提供運(yùn)行平臺(tái),而不是提供強(qiáng)大的云計(jì)算能力,或者說(shuō)不是提供分布式計(jì)算能力。當(dāng)然,提供分布式計(jì)算能力也會(huì)被稱為云計(jì)算,但不是我現(xiàn)在的方向。


  CF做為一個(gè)PAAS平臺(tái),目前已支持了以上理解的大多數(shù)基礎(chǔ)功能。但仍然有很多地方需要完善,比如router的負(fù)載均衡策略還很簡(jiǎn)單,對(duì)應(yīng)用的監(jiān)控還比較有限。但它的確給我們提供了一個(gè)非常漂亮的架構(gòu),使得我們有機(jī)會(huì)走近paas,而不是仍然不知道它該是什么樣的狀態(tài)。盡管,這個(gè)架構(gòu)在性能方面表現(xiàn)的還有待推敲。


  與CF一樣類似的產(chǎn)品,比較火熱的有heroko/openshift, 其它還有beantalk、google app engine等。

  基于Cloud Foundry的PaaS實(shí)踐(一) 綜述

  參見(jiàn)http://www.vmware.com/files/pdf/cloud/VMware-Taneja-Group-An-Overview-Of-The-Cloud-Market.pdf?

  還可參見(jiàn):http://socialcompare.com/en/comparison/platform-as-a-service-paas-for-cloud-applications-Scalable-cluster-of-services?


  基于Cloud Foundry的PaaS實(shí)踐之: Cloud Foundry集群部署

  單結(jié)點(diǎn)的部署由于vmware提供的安裝腳本,使用簡(jiǎn)單不再陳述,大家參照一下官網(wǎng)即可,在此主要談?wù)劧嘟Y(jié)點(diǎn)集群部署的要點(diǎn)。 (關(guān)于Cloud Foundry 的整體介紹,大家可參閱 深入 Cloud Foundry(上)?及 深入Cloud Foundry(下)?先 )


  2011年7月時(shí),搭建Cloud Foundry 集群時(shí),一篇國(guó)外的博文給了兩個(gè)建議:一種是在每個(gè)結(jié)點(diǎn)上分別安裝各個(gè)組件;一種是在每個(gè)結(jié)點(diǎn)上安裝全部組件,然后在每個(gè)結(jié)點(diǎn)僅啟動(dòng)部分組件,組件間通過(guò)配置相連,實(shí)踐證明這是最方便的方法。如果是在AWS-EC2部署集群,可以將一個(gè)結(jié)點(diǎn)安裝好后,做成AMI,然后用AMI瞬間launch一個(gè)集群,再配置一個(gè)各個(gè)組件的配置文件,一會(huì)功夫就可以建立起一個(gè)集群。


  下面說(shuō)一個(gè)組件互聯(lián)的配置。

  Cloud Foundry整體架構(gòu)的核心是基于消息機(jī)制的組件互聯(lián)(未必得當(dāng)),所有組件的互聯(lián)通訊依靠nats-server, 這是一個(gè)用ruby實(shí)現(xiàn)A lightweight publish-subscribe and distributed queueing messaging system. 使用極其簡(jiǎn)單,大家參考下https://github.com/derekcollison/nats。了解了nats,就抓住了Cloud Foundry的總線,然后大家再逐個(gè)熟悉各個(gè)組件的功能,當(dāng)然構(gòu)建一個(gè)多結(jié)點(diǎn)的Cloud Foundry也就簡(jiǎn)單的多了。nats的單結(jié)點(diǎn)安裝,只要安裝好ruby運(yùn)行環(huán)境后,執(zhí)行g(shù)em install nats安裝,再執(zhí)行nats-server啟動(dòng),默認(rèn)監(jiān)聽(tīng)4222。


  所有組件的config目錄下都有“組件名.yml”文件,將其中的"mbus: nats://10.134.226.8:4222/ "中的IP地址調(diào)整成啟動(dòng)nats-server的主機(jī)地址,如果是部署一個(gè)只有一個(gè)cloud_controller+health_manager結(jié)點(diǎn),任意多個(gè)dea/router結(jié)點(diǎn)的集群的話,集群就配置完成了。


  如果想啟動(dòng)多個(gè)cloud_controller和health_manager結(jié)點(diǎn),還有兩個(gè)工作要做:

  創(chuàng)建文件存儲(chǔ)共享和可跨主機(jī)訪問(wèn)的數(shù)據(jù)庫(kù)。


  數(shù)據(jù)庫(kù)存儲(chǔ)可使用rails框架支持的任何數(shù)據(jù)庫(kù),筆者推薦使用mysql,運(yùn)行在兩個(gè)主機(jī)上并配置Replication功能,將cloud_controller和health_manager的數(shù)據(jù)庫(kù)配置均指向mysql-master;


  文件存儲(chǔ)共享,可選用NFS,但當(dāng)云中主機(jī)數(shù)量很多的時(shí)候,NFS可能 效率不是最優(yōu),建議其它支持FUSE的分布式存儲(chǔ)解決方案,比如moosefs;多個(gè)cloud_controler需要共享 droplets: /var/vcap/shared/droplets和resources: /var/vcap/shared/resources。以使用NFS為例,每個(gè)cloud_controller需要將nfs-server上的存儲(chǔ),mount到本機(jī)。PaaS系統(tǒng)真正運(yùn)行起來(lái),這兩個(gè)目錄增長(zhǎng)會(huì)很快,因?yàn)榇鎯?chǔ)著整個(gè)集群的應(yīng)用程序副本和droplet副本,所以存儲(chǔ)一定要大些。另外,整個(gè)集群,我們可以任意毀掉任何一臺(tái)主機(jī)(當(dāng)然大多數(shù)時(shí)候不是故意的),再重新啟動(dòng)一個(gè)新的主機(jī)替代。但只要共享的文件存儲(chǔ)和數(shù)據(jù)庫(kù)數(shù)據(jù)不丟,整個(gè)集群就沒(méi)有任何變化。所以,相信同學(xué)們一定會(huì)重視這兩部分?jǐn)?shù)據(jù),定期備份到AWS-S3上,會(huì)HA啥的都不為過(guò)噢。


  集群中多個(gè)router啟動(dòng)后,負(fù)載均衡是必不可少的,筆者使用過(guò)兩個(gè)方案,一個(gè)是用Nginx,考慮到一個(gè)nginx并發(fā)功能支撐能力有限,可部署多個(gè)nginx;另外一種方案,可使用AWS的ELB,不過(guò)ELB給我們可配置的東西太少,好在AWS很專業(yè),不妨一試,不過(guò)較好給幾個(gè)留幾個(gè)nginx混著用免得AWS再停電了,整個(gè)系統(tǒng)都掛了。大家有別的方案歡迎推薦哈。


  另外一個(gè)需要特別關(guān)注的配置是本機(jī)IP,Cloud Foundry各個(gè)組件再向router注冊(cè)時(shí)是根據(jù)配置提取本機(jī)IP,默認(rèn)是127.0.0.1,必須改成實(shí)際IP,相關(guān)配置有:

  cloud_controller.yml:local_route: 10.134.226.8

  dea/config/dea.yml:local_route: 127.0.0.1

  health_manager/config/health_manager.yml:local_route: 10.134.226.8

  的代碼最近未來(lái)得及看,但考慮到代碼不斷更新,但本文無(wú)法時(shí)時(shí)更新,建議大家以此類推。

  對(duì)于配置文件的其它項(xiàng),不影響集群的建立,在此不再多說(shuō),如果有問(wèn)題可以與我聯(lián)系。


  介紹源碼前,先介紹兩個(gè)重要的內(nèi)容。了解整個(gè)Cloud Foundry需要熟悉的內(nèi)容很多,但最核心的東西是nats和event-machine. 關(guān)于nats上一篇已經(jīng)做了介紹,大家可參考基于Cloud Foundry的PaaS實(shí)踐(二) Cloud Foundry集群部署 ,安裝一下執(zhí)行個(gè)小示例程序便可一目了然。關(guān)于event-machine,大家可參考EventMachine-scalable-non-blocking-i-o-in-ruby 和 eventmachine_introduction_10.pdf 。簡(jiǎn)而言之,就是一個(gè)用很牛的算法(reactor)寫(xiě)的一個(gè)非阻塞的socket通信框架,有多種語(yǔ)言的實(shí)現(xiàn),nats也用到。同樣的,照著上面資料中的示例執(zhí)行一下,就明白了。


  有了以上的基礎(chǔ),我們可以開(kāi)始共同看一下Cloud Foundry的核心,cloud_controller.


  Cloud_Controller負(fù)責(zé)整個(gè)Cloud Foundry的用戶管理/應(yīng)用管理/服務(wù)管理,基于rails框架對(duì)外提供RESTFUL接口服務(wù)。我們可以通過(guò)分析一般rails應(yīng)用的方法加以分析。rails應(yīng)用的掌握個(gè)人喜歡通過(guò)MVC框架和RESTFUL接口把握。


  首先,看一下cloud_controller/config/routes.rb:

基于Cloud Foundry的PaaS實(shí)踐(三)Cloud Foundry 源碼分析 I

  按列從左至右依次為:http方法/訪問(wèn)路徑/代碼文件和函數(shù)信息/略。以第一行為例,如果cloud_controller接收到http get請(qǐng)求info路徑信息,將使用cloud_controller/app/default_controller.rb文件中的info函數(shù)響應(yīng)。以上供剛剛接觸rails的同學(xué)參考。


  了解了routers.rb的路由方法后,還可以使用wireshark工具,安裝vmc(安裝ruby后執(zhí)行g(shù)em install vmc),通過(guò)vmc help幫助執(zhí)行vmc 命令的同時(shí),用wireshark抓取http包,剛cloud_controller RESTFUL接口可完全把握。下面使用Linux的curl工具,顯示示例包如下:

基于Cloud Foundry的PaaS實(shí)踐(三)Cloud Foundry 源碼分析 I

  當(dāng)然,這個(gè)應(yīng)答信息顯示的不夠全面,大家還是wireshark,我這臺(tái)電腦沒(méi)裝,暫時(shí)就不能截圖了。另外,大家也可以使用Advance RESTclient,示例:

基于Cloud Foundry的PaaS實(shí)踐(三)Cloud Foundry 源碼分析 I

  到此,我們已經(jīng)可以把握全部restful接口,以及每個(gè)接口執(zhí)行的路徑,再列一下cloud_controller/app目錄下的文件,一目了然。


  在看代碼之前,較好再看一下數(shù)據(jù)模型。我曾經(jīng)畫(huà)了個(gè)模型圖,可惜暫時(shí)找不到了,先做個(gè)文字介紹吧。

  cloud_controller的主要數(shù)據(jù)模型包括:

基于Cloud Foundry的PaaS實(shí)踐(三)Cloud Foundry 源碼分析 I

  (臨時(shí)畫(huà)的簡(jiǎn)表,抱歉未添加表關(guān)系和示例數(shù)據(jù),過(guò)兩天要是翻到我寫(xiě)的手冊(cè)就補(bǔ)上)。


  表的內(nèi)容不難,此處列出的只是比較主要的,可能會(huì)有變化,但相信這里的大部分東西不會(huì)大變。特別說(shuō)明,service在Cloud Foundry中指的是System Service,比如Cloud Foundry會(huì)根據(jù)用戶的需要,由用戶執(zhí)行vmc create-server mysql后,為用戶創(chuàng)建一個(gè)mysql,然后執(zhí)行vmc bind-service mysql-name app-name后,就將此服務(wù)和應(yīng)用綁定,即應(yīng)用可以訪問(wèn)VCAP_SERVICES環(huán)境變量,得到這個(gè)mysql實(shí)例的連接信息,包括用戶名/密碼/IP/端口啥的。這塊目前Cloud Foundry支持API,用法更加簡(jiǎn)單,但原理如是。實(shí)現(xiàn)的信息會(huì)保存在services表中,連接信息會(huì)保存在binding_tokens表中,服務(wù)綁定信息會(huì)放在service_bindings表中,服務(wù)版本信息會(huì)保存service_configs中。大家可以執(zhí)行一下命令,看看表中數(shù)據(jù)的變化即可頓悟。


  另外,就是最配置文件,cloud_controller/config/cloud_controller.yml,這里面注釋較清楚,需要細(xì)看一下不再多說(shuō)

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

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

相關(guān)文章

  • PaaS未來(lái)世界

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

    Lavender 評(píng)論0 收藏0
  • IBM Bluemix開(kāi)啟云開(kāi)發(fā)時(shí)代

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

    cocopeak 評(píng)論0 收藏0
  • 云計(jì)算在企業(yè)級(jí)市場(chǎng)戰(zhàn)役已經(jīng)打響

    摘要:云計(jì)算在企業(yè)級(jí)市場(chǎng)的戰(zhàn)役已經(jīng)打響等新興云服務(wù)提供商已經(jīng)動(dòng)了傳統(tǒng)巨頭在企業(yè)級(jí)市場(chǎng)的奶酪,傳統(tǒng)巨頭們也已開(kāi)始奮力反擊。新浪的版本發(fā)布是一個(gè)出現(xiàn)在圖中的國(guó)內(nèi)事件。改名成發(fā)布微軟上臺(tái)后即將改名為,這標(biāo)志著云已經(jīng)成為微軟的優(yōu)先戰(zhàn)略方向。 云計(jì)算在企業(yè)級(jí)市場(chǎng)的戰(zhàn)役已經(jīng)打響:AWS等新興云服務(wù)提供商已經(jīng)動(dòng)了傳統(tǒng)IT巨頭在企業(yè)級(jí)市場(chǎng)的奶酪,傳統(tǒng)巨頭們也已開(kāi)始奮力反擊。隨著傳統(tǒng)IT 巨頭的加入,PaaS市場(chǎng)變...

    ermaoL 評(píng)論0 收藏0
  • 一招鮮吃遍天,做好混合云,這招管用

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

    iOS122 評(píng)論0 收藏0
  • Cloud Foundry——Azure殺手?

    摘要:最近推出了獨(dú)具創(chuàng)新的。能否戰(zhàn)勝微軟事實(shí)上,的血統(tǒng)將嚴(yán)重影響到它成為企業(yè)的可行性選擇,它不會(huì)吸引用戶。微軟的在成熟性上更好,而且它的備份是通過(guò)自身的專用基礎(chǔ)設(shè)施。的基礎(chǔ)構(gòu)建被擺在了微軟商店首要位置上。是針對(duì)開(kāi)發(fā)者和并不熱衷于微軟的商店。 VMware最近推出了獨(dú)具創(chuàng)新的Cloud Foundry。這款平臺(tái)及服務(wù)無(wú)疑有著新派傾向:用戶將可以注冊(cè)并開(kāi)發(fā)像MySQL和MongoDB這樣的運(yùn)行數(shù)據(jù)庫(kù)...

    yy13818512006 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<