摘要:上面主要是將新的多了些什么。在新版本的設(shè)計中,他們使用腳本來代替原先的腳本??梢钥吹皆谛碌募軜?gòu)中多出了很多組件。他究竟是如何操作的呢首先,我們必須準備好系統(tǒng)例如。當剛剛推出的時候,包含了應用運行時啟動,停止等簡單命令。
CloudFoundry距離發(fā)布已經(jīng)一年多了。在這一年里CloudFoundry不論是社區(qū)還是代碼日臻成熟,擁有了眾多合作伙伴?,F(xiàn)在他邁開了更大的腳步,新的CloudFoundry已經(jīng)逐漸浮出水面。
新版的CloudFoundry對于開發(fā)者來說,除了可以支持給多的Framework,提供更多類型的Service之外,沒有太多變化。但是CloudFoundry本身的架構(gòu)做了很多改進,可靠性,擴展性和安全性都有了質(zhì)的提升,而所有的一切都發(fā)生在背后。
一、新的功能
CloudFoundry提供了一些開發(fā)者們期冀的新功能。
可以和Service直接通信的Tunnel。作為開發(fā)者的我們往往希望可以使用客戶端工具直接連接到DB上調(diào)試。但是在CloudFoundry將DB作為Service隱藏在背后,這樣可以提供了諸多方便服務(wù),卻讓我們無法直接連接到DB。CloudFoundry已經(jīng)解決了這個問題,可以使用vmctunnel工具,直接訪問云后的服務(wù)。
遺留系統(tǒng)的接入支持。如果你有自己的DB或者已經(jīng)有一個遺留系統(tǒng)不想讓CloudFoundry托管,但是又想獲得CloudFoundry的PaaS服務(wù)?,F(xiàn)在有了一個完善的解決方案。開發(fā)者可以將DB或者遺漏系統(tǒng)包裝成一個Service。然后可以在CloudFoundry中注冊,這樣就可以自由的訪問了。
更多的Framework支持。CloudFoundry之前已經(jīng)支持很多的框架。有Spring forJava, Rails and Sinatra for Ruby, and Node.js?,F(xiàn)在CloudFoundry將支持更多的Framework。有
o-> Java平臺
> Grails模仿Rails的Java平臺實現(xiàn)
> Java_web 普通Java web程序
> Lift基于Scale的web框架
> Spring 流行的Java框架
o-> Ruby平臺
> Rack 最小化的Ruby Web框架
> Rails3 一站式的Ruby Web框架
> Sinatra 極簡主義的Ruby Web框架
o-> Python平臺
> Django 最流行的PythonWeb框架
> Wsgi Python的CGI
o-> 其他平臺
> Static page 靜態(tài)頁面
> node.js 異步Web框架
> Erlang
> php
> standalone 獨立的程序
隨著時間的推移,支持的框架將越來越多。你也可以自定義自己的框架,只需要實現(xiàn)不多的代碼。其中Standalone是比較特殊的。開發(fā)者的程序只要能啟動并監(jiān)聽一個端口,就可以作為一個程序運行在CloudFoundry上。提供了非常大的靈活性。
更多的Service支持。除了更多的框架 支持,CloudFoundry增加了更多的服務(wù)?,F(xiàn)在除了支持MySQL, MongoDB 和 Redis外。還支持很多服務(wù)。
×-> DB
- Mongodb 最流行的NoSQL數(shù)據(jù)庫
- Mysql傳統(tǒng)開源關(guān)系數(shù)據(jù)庫
- Neo4j圖數(shù)據(jù)庫
- PostgreSQL Mysql的有力競爭者
- Redis極快的內(nèi)存KV數(shù)據(jù)庫
×-> 存儲
- Atmos EMC專業(yè)存儲
- FileSystem 遠程NFS支持
- Vblob 提供Amazon S3支持
×-> 其他
- RabbitMQ 出色的Erlang隊列系統(tǒng)
現(xiàn)在服務(wù)逐漸完善,覆蓋主流的數(shù)據(jù)庫和存儲。也可以通過上文提到的ServiceBroker來接入任何一個外部服務(wù)。沒有做不到,只有想不到。
上面主要是將新的CloudFounry多了些什么。事實上,新的版本80%的工作在于對基礎(chǔ)架構(gòu)的改進。下面仔細闡述,CloudFoundry做了什么讓他的架構(gòu)更可靠。如果不熟悉前代的架構(gòu)的話,可以參見《深入Cloud Foundry》
二、ROUTER
上個版本中。Router作為一個nginx腳本存在。所以的請求都必須經(jīng)過Ruby代碼,然后加以轉(zhuǎn)發(fā)。這個設(shè)計干凈利落,不過Ruby也因此轉(zhuǎn)發(fā)了大量的數(shù)據(jù),容易引起性能問題,所以下個版本中做了如下的改進。
在新版本的設(shè)計中,他們使用Lua腳本來代替原先的Ruby腳本。而Lua腳本會對請求加以分析,轉(zhuǎn)發(fā)給Ruby程序,然后Ruby程序再將分析的結(jié)果返回。這樣一來,proxied request已經(jīng)不再經(jīng)過Ruby代碼。邏輯和數(shù)據(jù)完美分離。性能和穩(wěn)定性都大幅提高了。
在前版設(shè)計中,當Router接收到請求后,會隨機分配一個Droplet來處理這個請求,這種方式使得用戶沒有辦法使用Session,因為連續(xù)的HTTP請求會被分發(fā)到不同的應用實例上處理。新版本設(shè)計中增加了對SESSION的支持,當Router發(fā)現(xiàn)用戶的請求中帶了cookie信息,它會在Cookie里暗藏一個Droplet的host,port地址。當有新的請求進來,Router通過解析Cookie得到上次的應用實例,然后盡量轉(zhuǎn)發(fā)到同一臺Droplet上。
三、STAGE
下面的新版CloudFoundry的架構(gòu)圖。
可以看到在新的CloudFoundry架構(gòu)中多出了很多組件。新架構(gòu)中將用戶驗證從Controller中剝離,提供更好的驗證服務(wù)。同時多出了一個多帶帶Stager。
在原有的架構(gòu)中,用戶上傳代碼后,Cloud Control會將這部分代碼結(jié)合CloudFoundry打包成DEA可以運行的格式,并上傳到一個NFS中,當DEA啟動的時候,會從NFS取到需要相應的包,然后再運行。
由于打包(Stage)的過程,比較復雜還需要操作大量的文件,需要的時間比較長,單薄的CloudController不堪重負,所以將其移出,成為一個多帶帶的進程。每當CloudController需要打包的時候,就會向Stage隊列中發(fā)送一個請求,Stage收到請求后,逐個處理之。
眾所周知,不管是Java,Python還是Ruby程序都會有一系列的依賴,例如Ruby的Gem。每次打包的時候,都需要下載很多Gem,這是費時費力不討好的。所以開發(fā)了PackageCache模塊來緩存常用的依賴包。這樣的話,打包的過程會順暢很多。
原先性能問題算是解決了。但CloudFoundry還是個注重高可用的系統(tǒng),按照原先的設(shè)計,存放運行包的NFS是一處單點,一旦Crash,整個CloudFoundry的部署功能都將癱瘓。這是不能容忍的,而且越來越大的規(guī)模,一臺機器遲早無法容納全部的運行包。所以使用了BlobStore模塊,來替代原先的NFS,提供高可用可擴展的存儲服務(wù)。
四、SERVICE BROKER
Service Broker可以讓Cloudfoundry輕松的支持遺留系統(tǒng)或者不愿意讓CloudFoundry托管的系統(tǒng)。他究竟是如何操作的呢?
首先,我們必須準備好系統(tǒng),例如postgress。我們配置好程序和防火墻,讓CloudFoundry能通過類似
postgres://xyzhr:[email protected]:5432/xyz_hr_db 的URL來訪問到服務(wù)。
然后,調(diào)用create service,系統(tǒng)會在ServiceBroker中記錄你的配置信息。這樣就算大功告成了。Bind和其他的過程都有ServiceBroker完成,其實僅僅就是記錄信息,沒有實際操作。使用這個新的Service的時候和使用CloudFoundry的內(nèi)部Service沒有兩樣,配置參數(shù)都會通過環(huán)境變量傳入。所以當App訪問Service的時候,就與ServiceBroker無關(guān)了。
五、DEA
DEA是App的運行環(huán)境,全稱是DropletExecution Agent。一臺虛擬機上會運行一個或多個DEA。一個DEA可以啟動多個App(又稱Droplet)。所以我們大家的App都會由DEA啟動并管理。
當CloudFoundry剛剛推出的時候, Droplet包含了應用運行時啟動,停止等簡單命令。用戶應用可以隨意訪問文件系統(tǒng),也可以在內(nèi)網(wǎng)暢通無阻,跑滿CPU,占盡內(nèi)存,寫滿磁盤。你一切可以想到的破壞性操作都可以做到,太可怕了。CloudFoundry顯然不會放任這樣的情況太久,現(xiàn)在他們開發(fā)出了Warden,一個程序運行容器。這個容器提供了一個孤立的環(huán)境,Droplet只可以獲得受限的CPU,內(nèi)存,磁盤訪問權(quán)限,網(wǎng)絡(luò)權(quán)限,再沒有辦法搞破壞了。
Warden在Linux上的實現(xiàn)是將Linux 內(nèi)核的資源分成若干個namespace加以區(qū)分,底層的機制是CGROUP。這樣的設(shè)計比虛擬機性能好,啟動快,也能夠獲得足夠的安全性。在網(wǎng)絡(luò)方面,每一個Warden實例有一個虛擬網(wǎng)絡(luò)接口,每個接口有一個IP,而DEA內(nèi)有一個子網(wǎng),這些網(wǎng)絡(luò)接口就連在這個子網(wǎng)上。安全可以通過iptables來保證。在磁盤方面,每個warden實例有一個自己的filesystem。這些filesystem使用aufs實現(xiàn)的。Aufs可以共享warden之間的只讀內(nèi)容,區(qū)分只寫的內(nèi)容,提高了磁盤空間的利用率。因為aufs只能在固定大小的文件上讀寫,所以磁盤也沒有出現(xiàn)寫滿的可能性。
LXC是另一個Linux Container。那為什么不使用它,而開發(fā)了Warden呢。因為LXC的實現(xiàn)是和Linux綁死的,CloudFoundry希望warden能運轉(zhuǎn)在各個不同的平臺,而不只是Linux。另外Warden提供了一個Daemon和若干Api來操作,LXC提供的是系統(tǒng)工具。還有最重要的一點是LXC過于龐大,Warden只需要其中的一點點功能就可以了,更少的代碼便于調(diào)試。
六、結(jié)語
至此,我們已經(jīng)全面的瀏覽了CloudFoundry的新功能,新設(shè)計。云計算的大潮浩浩湯湯,CloudFoundry作為第一個開源的PaaS平臺日臻成熟,實用。但未來還會有更多更好設(shè)計等著我們發(fā)現(xiàn),屆時我們再一起分享。
關(guān)于作者
顏開,EMC中國研究院研究員,關(guān)注大數(shù)據(jù),云計算等領(lǐng)域
博客: http://weibo.com/yankaycom
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/3625.html
續(xù)與回顧 本文第一部分介紹了CloudFoundry的整體架構(gòu),并在最后花了一點篇幅簡介CloudFoundry的代碼組織情況,以便于讀者自己去研究源代碼。筆者認為開源項目較大的好處在于:當你讀懂源代碼、理解總體架構(gòu)后,能夠成竹在胸,并吸收為己用(有點類似武俠小說中的北冥神功)。為己用就是本篇要說的內(nèi)容:我們使用CloudFoundry搭建自己的私有PaaS平臺。 在介紹CloudFoundry之...
引子 今年4月份,VMware突然發(fā)布了業(yè)內(nèi)第一個開源的PaaS——CloudFoundry。幾個關(guān)鍵字:開源、PaaS、VMware,如果你對云計算感興趣,就沖著它的ApacheV2協(xié)議,如果不去GitHub拿它的代碼好好研讀一下,真有點對不起自己。筆者當時就是以這樣的心態(tài)去研究它的代碼,并把它部署在我們labs里面。發(fā)布至今的這幾個月里,筆者一直關(guān)注它的演進,并從它的架構(gòu)設(shè)計中獲益良多,...
摘要:執(zhí)行后,開始啟動,最終出現(xiàn)下圖就說明成功了共啟動了個模塊。需要兩個文件和一個文件夾我在我的機子上找到這些文件,分別拷貝到相應的目錄,就了。安裝完后,執(zhí)行上面的步驟都執(zhí)行下,出現(xiàn)圖中的信息,說明安裝成功了,現(xiàn)在就可以在上面部署應用了。 作者:egg博客:http://blog.csdn.net/zhangerqing(轉(zhuǎn)載請說明出處)一、環(huán)境需求官方系統(tǒng)環(huán)境要求:Setup?a?VM?with...
摘要:首先從我的下載我寫好的到本地。安裝,然后執(zhí)行命令行,確保成功,在項目根目錄的文件夾內(nèi)生成了。將放到本地的文件夾下面。啟動本地,確保該本地工作成功。然后切換回項目根目錄,執(zhí)行部署到您的上。 首先從我的Github下載我寫好的hello world Servlet到本地。 安裝Maven,然后執(zhí)行命令行mvn clean install,確保build成功,在項目根目錄的target文件夾...
閱讀 835·2023-04-25 19:40
閱讀 3492·2023-04-25 17:41
閱讀 3007·2021-11-11 11:01
閱讀 2623·2019-08-30 15:55
閱讀 3231·2019-08-30 15:44
閱讀 1361·2019-08-29 14:07
閱讀 485·2019-08-29 11:23
閱讀 1330·2019-08-27 10:54