作用
PaaS之所以能夠推進(jìn)SaaS的發(fā)展,主要在于它能夠提供企業(yè)進(jìn)行定制化研發(fā)的中間件平臺(tái),同時(shí)涵蓋數(shù)據(jù)庫(kù)和應(yīng)用服務(wù)器等。PaaS可以提高在Web平臺(tái)上利用的資源數(shù)量。例如,可通過(guò)遠(yuǎn)程Web服務(wù)使用數(shù)據(jù)即服務(wù)(Data-as-a-Service:數(shù)據(jù)即服務(wù)),還可以使用可視化的API,甚至像800app的PaaS平臺(tái)還允許你混合并匹配適合你應(yīng)用的其他平臺(tái)。用戶或者廠商基于PaaS平臺(tái)可以快速開發(fā)自己所需要的應(yīng)用和產(chǎn)品。同時(shí),PaaS平臺(tái)開發(fā)的應(yīng)用能更好地搭建基于SOA架構(gòu)的企業(yè)應(yīng)用。
此外,PaaS對(duì)于SaaS運(yùn)營(yíng)商來(lái)說(shuō),可以幫助他進(jìn)行產(chǎn)品多元化和產(chǎn)品定制化。例如Salesforce的PaaS平臺(tái)讓更多的ISV成為其平臺(tái)的客戶,從而開發(fā)出基于他們平臺(tái)的多種SaaS應(yīng)用,使其成為多元化軟件服務(wù)供貨商(Multi Application Vendor),而不再只是一家CRM隨選服務(wù)提供商。而國(guó)內(nèi)的SaaS廠商800app通過(guò)PaaS平臺(tái),改變了僅是CRM供應(yīng)商的市場(chǎng)定位,實(shí)現(xiàn)了 BTO(Built to order:按訂單生產(chǎn)),和在線交付流程。使用800app的PAAS開發(fā)平臺(tái),用戶不再需要任何編程即可開發(fā)包括CRM、OA、HR、SCM、進(jìn)銷存管理等任何企業(yè)管理軟件,而且不需要使用其他軟件開發(fā)工具并立即在線運(yùn)行。
面向個(gè)人的EC站點(diǎn)(electronic commerce site)的巨頭公司Amazon,把最初為了自己公司的運(yùn)營(yíng)用的構(gòu)筑起來(lái)的系統(tǒng)平臺(tái),進(jìn)行出租,用戶可以自由選擇操作系統(tǒng)和中間軟件,以這樣的方式提供硬件以及軟件平臺(tái)作為服務(wù),最初被海外以一些冒險(xiǎn)事業(yè)的企業(yè)所使用。從2006年開始 [Amazon EC] [Amazon S3]開始作為服務(wù)推向市場(chǎng)。
還有現(xiàn)代軟件業(yè)霸主同時(shí)又是次時(shí)代計(jì)算的先驅(qū)的Google,大家都知道在世界上構(gòu)筑以及運(yùn)行了非常多的數(shù)據(jù)中心。以搜索引擎以及新的廣告模式而聞名。他們使用便宜的計(jì)算機(jī)和強(qiáng)有力的中間件,以及自己的技術(shù)裝備出了世界上最強(qiáng)大的數(shù)據(jù)中心,以及超高性能的并行計(jì)算群。 2008年4月發(fā)表的PaaS服務(wù)[Google App Engine]和Amazon 的 EC2,S3,SimpleDB等服務(wù)擁有相似的功能。這些穩(wěn)定的平臺(tái)上同樣搜索引擎,GMail等服務(wù)也在運(yùn)行。同樣以ASP~SaaS成功的Salesforce,2007年開始用于提供SaaS的系統(tǒng)基盤對(duì)外公開,用Force這個(gè)名稱開始進(jìn)入PaaS業(yè)務(wù)。他所提供的PaaS服務(wù)里采用Java類似的語(yǔ)言Apex以及Eclipse開發(fā)平臺(tái),整合的開發(fā)環(huán)境也作為服務(wù)進(jìn)行提供(Development as a Service)。Google/Amazon/Salesforce這三個(gè)軟件巨頭非常的重視PaaS這種新的商業(yè)模式,Amazon的PaaS服務(wù)為了用戶可以自由的組合服務(wù)提供了更多的自由度,Google的話提供了更多的服務(wù)使用戶能夠方便的使用,去掉了一些繁瑣的作業(yè)。Google/Salesforce的PaaS不僅是基礎(chǔ)硬件的提供開發(fā)環(huán)境的同樣被提供屬于真正的平臺(tái)作為一種服務(wù)(PaaS)
特點(diǎn)
PaaS能將現(xiàn)有各種業(yè)務(wù)能力進(jìn)行整合,具體可以歸類為應(yīng)用服務(wù)器、業(yè)務(wù)能力接入、業(yè)務(wù)引擎、業(yè)務(wù)開放平臺(tái),向下根據(jù)業(yè)務(wù)能力需要測(cè)算基礎(chǔ)服務(wù)能力,通過(guò)IaaS提供的API調(diào)用硬件資源,向上提供業(yè)務(wù)調(diào)度中心服務(wù),實(shí)時(shí)監(jiān)控平臺(tái)的各種資源,并將這些資源通過(guò)API開放給SaaS用戶。PaaS主要具備以下三個(gè)特點(diǎn):
(1)平臺(tái)即服務(wù):PaaS所提供的服務(wù)與其他的服務(wù)最根本的區(qū)別是PaaS提供的是一個(gè)基礎(chǔ)平臺(tái),而不是某種應(yīng)用。在傳統(tǒng)的觀念中,平臺(tái)是向外提供服務(wù)的基礎(chǔ)。一般來(lái)說(shuō),平臺(tái)作為應(yīng)用系統(tǒng)部署的基礎(chǔ),是由應(yīng)用服務(wù)提供商搭建和維護(hù)的,而PaaS顛覆了這種概念,由專門的平臺(tái)服務(wù)提供商搭建和運(yùn)營(yíng)該基礎(chǔ)平臺(tái),并將該平臺(tái)以服務(wù)的方式提供給應(yīng)用系統(tǒng)運(yùn)營(yíng)商;
(2)平臺(tái)及服務(wù):PaaS運(yùn)營(yíng)商所需提供的服務(wù),不僅僅是單純的基礎(chǔ)平臺(tái),而且包括針對(duì)該平臺(tái)的技術(shù)支持服務(wù),甚至針對(duì)該平臺(tái)而進(jìn)行的應(yīng)用系統(tǒng)開發(fā)、優(yōu)化等服務(wù)。PaaS的運(yùn)營(yíng)商最了解他們所運(yùn)營(yíng)的基礎(chǔ)平臺(tái),所以由PaaS運(yùn)營(yíng)商所提出的對(duì)應(yīng)用系統(tǒng)優(yōu)化和改進(jìn)的建議也非常重要。而在新應(yīng)用系統(tǒng)的開發(fā)過(guò)程中,PaaS運(yùn)營(yíng)商的技術(shù)咨詢和支持團(tuán)隊(duì)的介入,也是保證應(yīng)用系統(tǒng)在以后的運(yùn)營(yíng)中得以長(zhǎng)期、穩(wěn)定運(yùn)行的重要因素;
(3)平臺(tái)及服務(wù):PaaS運(yùn)營(yíng)商對(duì)外提供的服務(wù)不同于其他的服務(wù),這種服務(wù)的背后是強(qiáng)大而穩(wěn)定的基礎(chǔ)運(yùn)營(yíng)平臺(tái),以及專業(yè)的技術(shù)支持隊(duì)伍。這種“平臺(tái)級(jí)”服務(wù)能夠保證支撐SaaS或其他軟件服務(wù)提供商各種應(yīng)用系統(tǒng)長(zhǎng)時(shí)間、穩(wěn)定的運(yùn)行。PaaS的實(shí)質(zhì)是將互聯(lián)網(wǎng)的資源服務(wù)化為可編程接口,為第三方開發(fā)者提供有商業(yè)價(jià)值的資源和服務(wù)平臺(tái)。有了PaaS平臺(tái)的支撐,云計(jì)算[1] 的開發(fā)者就獲得了大量的可編程元素,這些可編程元素有具體的業(yè)務(wù)邏輯,這就為開發(fā)帶來(lái)了極大的方便,不但提高了開發(fā)效率,還節(jié)約了開發(fā)成本。有了PaaS平臺(tái)的支持,WEB應(yīng)用的開發(fā)變得更加敏捷,能夠快速響應(yīng)用戶需求的開發(fā)能力,也為最終用戶帶來(lái)了實(shí)實(shí)在在的利益。
應(yīng)用
平臺(tái)即服務(wù)(PaaS)已存在了相當(dāng)長(zhǎng)的一段時(shí)間了,這是一種在基于云計(jì)算的系統(tǒng)中使用一套被提供的工具來(lái)開發(fā)和部署應(yīng)用程序的高效既定方法。
如果一家企業(yè)承受著把應(yīng)用程序軟件遷移至網(wǎng)絡(luò)或移動(dòng)設(shè)備的壓力,那么PaaS則具有明顯的優(yōu)勢(shì)。企業(yè)業(yè)務(wù)進(jìn)入市場(chǎng)的時(shí)間更短,這樣也就避免了開發(fā)時(shí)間冗長(zhǎng)、上市時(shí)間過(guò)長(zhǎng)的產(chǎn)品開發(fā)過(guò)程。這樣的產(chǎn)品必定是高質(zhì)量的,同時(shí)也必須能夠被快速提供。PaaS可讓企業(yè)更專注于他們所開發(fā)和交付的應(yīng)用程序,而不是管理和維護(hù)完整的平臺(tái)系統(tǒng)。
對(duì)于小型企業(yè)和初創(chuàng)型企業(yè)來(lái)說(shuō),PaaS也是比較有用的,因?yàn)檫@些企業(yè)并沒有廣泛的、具有較高依賴性的舊應(yīng)用程序需要遷移。PaaS的多租戶特性可實(shí)現(xiàn)應(yīng)用程序和數(shù)據(jù)資源的最大數(shù)量共享,同時(shí)讓開發(fā)資源繼續(xù)專注于應(yīng)用程序的交付和連接,而不是開發(fā)和支持?jǐn)?shù)據(jù)庫(kù)資源。PaaS的未來(lái)發(fā)展空間似乎在小型企業(yè)和初創(chuàng)企業(yè),這類公司由于不依賴于與舊應(yīng)用程序的集成而更適于在云計(jì)算中進(jìn)行應(yīng)用程序開發(fā)。[2]
PaaS區(qū)別
簡(jiǎn)單地說(shuō),PaaS平臺(tái)就是指云環(huán)境中的應(yīng)用基礎(chǔ)設(shè)施服務(wù),也可以說(shuō)是中間件即服務(wù)。PaaS平臺(tái)在云架構(gòu)中位于中間層,其上層是SaaS,其下層是IaaS[3] 。在傳統(tǒng)On-Premise部署方式下,應(yīng)用基礎(chǔ)設(shè)施即中間件的種類非常多, 有應(yīng)用服務(wù)器,數(shù)據(jù)庫(kù),ESBs, BPM, Portal,消息中間件,遠(yuǎn)程對(duì)象調(diào)用中間件等等。對(duì)于PaaS平臺(tái),Gartner把它們分為兩類,一類是應(yīng)用部署和運(yùn)行平臺(tái)APaaS(application platform as a service),另一類是集成平臺(tái)IPaaS(integration as a service)。 人們經(jīng)常說(shuō)的PaaS平臺(tái)基本上是指APaaS,如Force和Google App Engine。
國(guó)內(nèi)日前上線的中國(guó)云應(yīng)用平臺(tái),能夠?yàn)檐浖S商提供領(lǐng)先的IaaS基礎(chǔ)平臺(tái),使得軟件廠商能夠?qū)⒆⒁饬性谄鋺?yīng)用產(chǎn)品的云化之上,而將對(duì)基礎(chǔ)資源的需求,包括云服務(wù)器、云存儲(chǔ)、云監(jiān)控等完全依托在理念領(lǐng)先、技術(shù)成熟、安全可靠的IaaS平臺(tái)上。
中國(guó)云應(yīng)用平臺(tái)將加盟入駐的傳統(tǒng)軟件向SaaS軟件轉(zhuǎn)型,采用傳統(tǒng)軟件結(jié)合云計(jì)算IaaS的模式,逐步實(shí)現(xiàn)多租戶單實(shí)例的應(yīng)用架構(gòu)最終實(shí)現(xiàn)高性能應(yīng)用。未來(lái)大量傳統(tǒng)軟件企業(yè)在與華云數(shù)據(jù)的合作過(guò)程中,通過(guò)與PaaS平臺(tái)的整合,可以快速實(shí)現(xiàn)云化與SaaS化改造。
企業(yè)級(jí)
云計(jì)算[4] 起源于大型互聯(lián)網(wǎng)企業(yè)。對(duì)于互聯(lián)網(wǎng)企業(yè),成本壓力和指數(shù)級(jí)的業(yè)務(wù)增長(zhǎng)壓力使他們關(guān)注于物理資源的利用率和應(yīng)用的可擴(kuò)展性。在應(yīng)用服務(wù)器這層,通過(guò)Cluster Session來(lái)實(shí)現(xiàn)水平擴(kuò)展;在數(shù)據(jù)存儲(chǔ)這層,采用基于BASE模型的NOSQL數(shù)據(jù)存儲(chǔ)來(lái)實(shí)現(xiàn)擴(kuò)展。互聯(lián)網(wǎng)企業(yè)主導(dǎo)面向公眾服務(wù)的公有云PaaS平臺(tái),如Google App Engine和Amazon Beanstalk。對(duì)于公有云PaaS平臺(tái),PaaS就是云環(huán)境下的應(yīng)用部署平臺(tái)。
?。?)基于商業(yè)軟件的部署方式:Application - Framework/Libs - Websphere/Weblogic + RDBMS
?。?)基于開源軟件的部署方式:Application - Frameworks/Libs - Tomcat/JBoss + RDBMS
?。?)云環(huán)境下的部署方式:Application - Frameworks/Libs - PaaS(Goole App Engine, Amazon)
【注:1、WebSphere:是 IBM 的軟件平臺(tái)。它包含了編寫、運(yùn)行和監(jiān)視全天候的工業(yè)強(qiáng)度的隨需應(yīng)變 Web應(yīng)用程序和跨平臺(tái)、跨產(chǎn)品解決方案所需要的整個(gè)中間件基礎(chǔ)設(shè)施,如服務(wù)器、服務(wù)和工具。WebSphere 提供了可靠、靈活和健壯的軟件。
2、Weblogic:是一個(gè)基于Javaee架構(gòu)的中間件,BEA WebLogic是用于開發(fā)、集成、部署和管理大型分布式Web應(yīng)用、網(wǎng)絡(luò)應(yīng)用和數(shù)據(jù)庫(kù)應(yīng)用的Java應(yīng)用服務(wù)器。將Java的動(dòng)態(tài)功能和Java Enterprise標(biāo)準(zhǔn)的安全性引入大型網(wǎng)絡(luò)應(yīng)用的開發(fā)、集成、部署和管理之中。
3、Tomcat 服務(wù)器是一個(gè)免費(fèi)的開放源代碼的Web 應(yīng)用服務(wù)器
4、JBoss是一個(gè)管理EJB的容器和服務(wù)器,支持EJB 1.1、EJB 2.0和EJB3.0的規(guī)范。但JBoss核心服務(wù)不包括支持servlet/JSP的WEB容器,一般與Tomcat或Jetty綁定使用。
5、RDBMS:指的是關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)】
這種情況下,PaaS實(shí)質(zhì)上就是一個(gè)預(yù)先裝好的Web Container和一組公共服務(wù),如數(shù)據(jù)存儲(chǔ)服務(wù)(不一定是關(guān)系型數(shù)據(jù)庫(kù))、消息隊(duì)列、集中式session及cache等等。對(duì)于個(gè)人用戶或者簡(jiǎn)單應(yīng)用來(lái)說(shuō),公有云PaaS平臺(tái)使得開發(fā)人員僅關(guān)注應(yīng)用邏輯開發(fā)本身,不用把精力花費(fèi)在基礎(chǔ)實(shí)施和應(yīng)用的擴(kuò)展和維護(hù)上。
所謂企業(yè)級(jí)PaaS平臺(tái),主要包含兩類,一是大型企業(yè)內(nèi)部的私有云PaaS平臺(tái),另一類是面向ISV廠商的PaaS平臺(tái)。然而對(duì)于企業(yè)級(jí)PaaS平臺(tái),PaaS不僅僅是云環(huán)境下的應(yīng)用部署平臺(tái)。 拋開安全問題不講,私有云PaaS平臺(tái)和公有云PaaS有如下核心區(qū)別:
?。?)復(fù)雜的多租戶模型:對(duì)于公有云PaaS平臺(tái),其租戶模型是 (用戶-> 應(yīng)用 -> 應(yīng)用實(shí)例),一個(gè)用戶可以部署多個(gè)應(yīng)用,每個(gè)應(yīng)用可以有多個(gè)運(yùn)行時(shí)實(shí)例,應(yīng)用實(shí)例共享資源池。對(duì)于一個(gè)大型企業(yè),一個(gè)大部門可能是一個(gè)租戶,大部門下面的子部門也是一個(gè)租戶;或者一個(gè)SaaS應(yīng)用系統(tǒng)的一個(gè)實(shí)例就是一個(gè)租戶。對(duì)于租戶的資源使用,大部門租戶是共享資源池里面的資源,也可能某些關(guān)鍵租戶需要獨(dú)占一些資源以保證安全。
?。?)已有應(yīng)用的兼容:企業(yè)的歷史應(yīng)用都是基于關(guān)系型數(shù)據(jù)庫(kù)的,某些PaaS平臺(tái)不支持關(guān)系型數(shù)據(jù)存儲(chǔ),即使是簡(jiǎn)單的已有應(yīng)用都無(wú)法遷移到PaaS平臺(tái)上。
(3)復(fù)合應(yīng)用的構(gòu)建: 企業(yè)On-Premise應(yīng)用在很長(zhǎng)一段時(shí)間內(nèi)都是要存在的,私有云PaaS平臺(tái)要成為On-Premise和公有云之間的橋梁。私有云PaaS平臺(tái)除了是應(yīng)用部署平臺(tái)外,還需要提供集成和方便構(gòu)建復(fù)合應(yīng)用的能力,就是Gartner所提的iPaaS能力。 企業(yè)級(jí)PaaS平臺(tái)不僅僅是應(yīng)用部署平臺(tái),而且是復(fù)雜多租戶環(huán)境和復(fù)雜應(yīng)用環(huán)境下的共享基礎(chǔ)設(shè)施平臺(tái),是On-Premise部署通往公有云部署的必經(jīng)之路。
內(nèi)容來(lái)自百科網(wǎng)