云原生時代的應用PAAS模型OAM指的是什么,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
公司主營業(yè)務:網(wǎng)站建設、網(wǎng)站設計、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)公司是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)公司推出臺兒免費做網(wǎng)站回饋大家。
隨著kubernetes的興起,很多公司都有了Paas平臺建設的能力,但是應用Paas平臺建設上基本上都是形態(tài)各異,百花齊放,而OAM在筆者看來就是應用Paas平臺建設的kubernetes,未來的事實標準,今天讓我們一起來聊下OAM吧。
在聊OAM之前我們先聊下傳統(tǒng)的運維開發(fā),從運維系統(tǒng)到運維平臺的演進的過程,以及可能會遇到的問題
在傳統(tǒng)的運維開發(fā)中,基礎組件CMDB、自動化、監(jiān)控、發(fā)布、日志、流程幾個系統(tǒng)基本上已經(jīng)是標配,通過CMDB存儲元數(shù)據(jù),自動化提供原子操作,然后通過發(fā)布搞定持續(xù)交付, 通??梢詫⑦@個階段稱為1.0階段,該階段運維可以提供一定的支持能力,該階段運維主要目標是搞定內(nèi)部需求,對外輸出持續(xù)交付能力(僅僅是交付,大多數(shù)公司CI流程由測試把控,夸團隊的事情就自行體會吧)
平臺化階段主要目標就是通過運維系統(tǒng)的集成,盡可能的實現(xiàn)研發(fā)的自助操作,比較典型的就是基于ITSM實現(xiàn)上述流程平臺的聯(lián)動,研發(fā)填寫固定的工單,然后通過流程編排,整合當前的運維子系統(tǒng),實現(xiàn)某個場景的自助化操作,減少運維的參與度,提供研發(fā)效能,在這個過程中,可能會打通公司的一些別的團隊,比如數(shù)據(jù)庫、測試、中間件團隊,姑且稱之為2.0階段
服務化Paas主要是通過底層基礎設施、運維系統(tǒng)的服務化能力,并且公司內(nèi)部具有高度統(tǒng)一的目標,開始向云化轉變階段轉變,每個團隊都提供高度內(nèi)聚的服務化能力,同時對外提供該平臺全生命周期的管理能力。
這里我們要想明白服務化能力與系統(tǒng)功能的區(qū)別,比如說發(fā)布系統(tǒng)提供幾十個參數(shù),讓用戶提供隨意的定義,我理解這可能僅僅是功能,因為如果用戶自由度越高,證明平臺流程規(guī)范越不統(tǒng)一, 而且如果讓一個用戶用系統(tǒng)的時候,得先屢清楚你的幾十個功能參數(shù),上帝,祝你好運!而服務化的能力我理解上應該給用戶提供的是比如發(fā)布策略,盡可能少的控制參數(shù),標準化的流程,具體的復雜編排能力完全內(nèi)聚到平臺內(nèi)部,對用戶無感知。就稱之為3.0階段好了
在這個階段通常平臺的建設者就會考慮平臺下一步大的方向是什么,從當前的運維產(chǎn)品類中,我們可以分為三個方向:效能devops方向、Paas方向、運維門戶,但大家有一個很一致的目標就是提高研發(fā)效能,實現(xiàn)應用全生命周期管理
運維門戶方向其目標主要是覆蓋測試->發(fā)布->運維這三個階段,通過整合運維側的能力,比如cmdb、監(jiān)控、發(fā)布、日志等系統(tǒng)實現(xiàn)應用的統(tǒng)一操作,通常會結合公司的CMDB來實現(xiàn)業(yè)務樹來進行統(tǒng)一管理,其優(yōu)點是符合運維操作需求,個人理解其相對于devops和cloud屬于建設過程中的一個階段,主要強調(diào)的是整合。
效能devops方向典型的代表就是阿里的云效,從需求->開發(fā)->測試->發(fā)布->運維->運營實現(xiàn)全鏈路的覆蓋,在大多數(shù)工通常都是打通測試->發(fā)布->運維->運營這個鏈路就很不錯了,但是通常公司大概率不會做這個事情,只要稍微碰過的就知道這里面需求->開發(fā)->測試這幾個階段是多難打通了。
Paas方向除了測試->發(fā)布->運維->運營這個鏈路的覆蓋,很重要的一點是要提供云的基礎能力,其中很關鍵的能力:彈性、多租戶、自服務、按需付費,當然這有很多前提,比如你要彈性得公司有資源才行,按需付費也得公司想搞計費才行,但如果要做系統(tǒng)一定要想好,我們后續(xù)萬一要搞混合云呢?
關于運營的理解,運營在運維這側我目前理解就是維穩(wěn)、降本、提效,穩(wěn)定性應該是運維根本,運營的主要目標應該是后兩個。
降本是指的平臺可以通過一些機制去確定降低運行成本,其中典型的體現(xiàn)就是業(yè)務使用資源是否合理,無論是在k8s還是傳統(tǒng)的vm,都有個問題就是研發(fā)申請了了4h8g的機器,真的合理嘛?如果我們可以建立一套運營標準,比如我們可以根據(jù)業(yè)務在過去周、月、季度、甚至年的資源使用,通過統(tǒng)一的標準去衡量其資源使用率,那有沒有可能降低一些成本呢?
提效可能是很難衡量的一個指標,因為沒辦法做一個平臺之后,就說自己比之前提升了多少,更多的是可能是從用戶使用平臺到底需要多長時間,比如上線應用,從應用創(chuàng)建、資源申請、線上交付一共花了多長時間?比如如果公司提供統(tǒng)一的腳手架,腳手架關聯(lián)標準化建設,打通CI、CD、監(jiān)控、日志、安全等等功能,那研發(fā)是不是只需要從git上拉下項目,然后進行代碼開發(fā),最終上線的時候,申請下資源即可?
當然這只是筆者的想法,也沒有實踐,感興趣的可以一起聊聊想法,畢竟這個可能比AIops這些可能更容易落地一些。
其實不論是在效能還是Paas中,我們都有在做同一件事情,就是應用的全生命周期管理,但是我們會發(fā)現(xiàn)不同方向、不同公司的應用定義絕對是千差萬別,而且針對應用全生命周期托管沒有統(tǒng)一的規(guī)范,而且大多數(shù)公司的運維研發(fā)團隊規(guī)模都并不大,如何設計出高內(nèi)聚、低耦合、可擴展、分布式的應用Paas平臺,發(fā)際線估計又要高不少。
在當下云原生時代,大家可以基于k8s的Paas(Saas)云原生的能力快速構建公司的容器云平臺,我們可能會自己搞個App然后結合Service、DEployment等資源去描述一個應用,然后針對日志/監(jiān)控等進行改造適配,其實大家潛移默化的就在遵循共同的一種標準,其實就是k8s提供給你的,但是針對應用依賴,比如MySQL、redis這種信息怎么描述呢?針對中間件這種又該怎么描述呢?這就是今天的主角OAM
OAM 全稱是 Open Application Model,從名稱上來看它所定義的就是一種模型,同時也實現(xiàn)了基于 OAM 的我認為這種模型旨在定義了云原生應用的標準。
開放(Open):支持異構的平臺、容器運行時、調(diào)度系統(tǒng)、云供應商、硬件配置等,總之與底層無關
應用(Application):云原生應用
模型(Model):定義標準,以使其與底層平臺無關
該段描述引用自宋老師的文章,參考附錄1
這里我說說我的理解,我們做平臺的都會有個痛點就是千奇百怪的設計,幾年沒動的停機可能起不來應用,誰特么都不敢動,而基于Model,我理解就是,翻滾吧牛寶寶,當然更大的目標肯定是大家有同一個標準,同一個夢想,而且擁有統(tǒng)一的視角。Open開放有兩層含義,1)支持異構:我們通過標準的模型聲明,接納云、虛擬機、物理機、容器不同的基礎設施,這意味著我們可以無限的擴容我們的平臺 2)云原生時代,我們可以復用各種基礎設施,讓小作坊,也可以體驗下五星級酒店的感覺,通過復用云廠商、開源社區(qū)可以讓我們平臺無縫享受開源社區(qū)的能力, 接下來讓我們一起看看OAM是怎么實現(xiàn)這邊目標
Component是應用組成的一部分,通常由開發(fā)進行描述,如下部分都可以描述為一個Component: 1.研發(fā)將自己的程序打包成一個鏡像,通過Deployment部署 2.研發(fā)聲明需要使用一個4核8G的mysql5.7的數(shù)據(jù)庫
這兩個描述都是component,簡而言之研發(fā)可以描述的都可以稱為Component,因為他們都是組成Application的一部分,這個部分的Model體現(xiàn)主要是體現(xiàn)在我們通過Component的標準化,可以讓研發(fā)只需要關注極少數(shù)的需要知道的東西,就可以完成一個應用在研發(fā)角度的定義
在這一層我理解基礎設施團隊提供給研發(fā)定義應用的能力,研發(fā)只需要根據(jù)應用需要聲明對應的component組件, 而并不關注底層的基礎設施具體的實現(xiàn)
Trait則是運維和基礎架構服務化的能力提供手段,運維可以根據(jù)應用的描述,來給應用加對應的Trait,那什么可以稱之為一個Trait呢?比如彈性擴縮容可能是一種Trait,日志可能是一種Trait、監(jiān)控可能也是一種Trait,幾個實際Trait: 1.研發(fā)上線一個java應用,運維這邊根據(jù)標準化和服務化能力,就會自動加入對應的監(jiān)控,這其實就是監(jiān)控的服務化能力 2.應用灰度發(fā)布,發(fā)現(xiàn)問題,主動進行回滾,這其實是發(fā)布系統(tǒng)服務化能力的體現(xiàn)
通過運維能力的輸出, 研發(fā)就不需要關注底層的各種運維細節(jié),只需要聲明應用想擁有的能力,就可以通過實現(xiàn)底層應用運維的自動化托管,不需要關注底層的任何細節(jié),而且各種運維能力可以自由組合,實現(xiàn)應用穩(wěn)定高效的運行
Policy實際上是Component中的概念,體現(xiàn)的其實是研發(fā)訴求,比如研發(fā)提出我的應用需要響應延遲在100ms以內(nèi),那運維就可以根據(jù)這個Policy結合自己的服務化能力,提供對應的Trait, 研發(fā)其實并不需要知道運維是如何保障SLA的,只需要提供研發(fā)訴求Policy,其實就可以完成訴求傳遞,一切可描述,可度量
研發(fā)通過聲明Policy傳遞訴求,運維根據(jù)訴求結合運維能力,提供對應的保障,一切都是數(shù)據(jù)化的,既是運維服務化能力的體現(xiàn),也是研發(fā)和運維彼此信任的良好橋梁,同時研發(fā)也并不需要關注各種底層的細節(jié)
應用邊界中我們首先要理解邊界,邊界主要是定義具有某些意義的一類應用的邊界,比如在公有云環(huán)境中,通常會根據(jù)VPC網(wǎng)絡劃分邊界,通過統(tǒng)一的網(wǎng)絡配置,可以劃分出多個網(wǎng)絡區(qū),這些都屬于Application Scope。更復雜的場景則是多數(shù)據(jù)中心,快速止損,當前大多數(shù)公司為了災備都會有多個數(shù)據(jù)中心,那其實每個數(shù)據(jù)中心都會劃分為一個邊界,如果發(fā)現(xiàn)某個中心突然掛掉了,即對應的Application Scope下面的
而且ApplicationScope可以任意組合,我們可以通過這種玩法,將要進行某一類的應用進行統(tǒng)一的管理,關注其對應的狀態(tài),進而結合我們的Trait來實現(xiàn)各種場景的建設
上面我們聲明了組成應用的component, 同時附加了運維的Trait, 還通過AapplicationScope,劃分了對應的網(wǎng)絡或者應用層的邊界, 這些組件都是獨立聲明,可以獨立進行演進,實現(xiàn)了應用接入配置的標準化、模型化、松耦合、自由裝配,剩下的一步就是通過Application Configuration去將Conponent、Trait、ApplicationScope等組合起來,即就是我們最終的應用聲明,基于這份聲明結合面向終態(tài)的設計,OAM會按照規(guī)則分別進行各個組件的托管,同時我們也可以復用社區(qū)優(yōu)秀的Component和Trait來實現(xiàn)平臺的快速交付。
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。