這周Jerry在SAP上海研究院參加了一個爲期4天的Kubernetes培訓,度過了忙碌而又充實的4天。Jason,Benny和Peng三位大神的培訓乾貨滿滿,藉此機會,Jerry和過去的兩位老領導Patrick和Evan敘了敘舊,也拜見了上海SAP圈子裏的幾位大佬。之前在網絡上久聞大名,此次終於見到了大佬們本人,了卻我一樁心願。html
爲何SAP內部也在開展Kubernetes的培訓呢?誕生於2015年7月的Kubernetes,是Google內部多年使用的容器集羣管理系統Borg的開源版本。因爲凝聚了Google在容器編排領域多年的深厚功力,發佈以後很快就一飛沖天,現在已經成爲事實上的容器集羣管理領域的標準和霸主。node
咱們知道Docker的logo「萌萌噠」,一頭馱着軟件鏡像的集裝箱在IT世界的汪洋裏自由遨遊的鯨魚。git
而Kubernetes的logo,則體現了Google這家老牌IT企業的睿智和大氣。Kubernetes源自古希臘語,意爲「舵手」,Google的用意昭然若揭:Kubernentes(舵手)就是Google在雲時代裏,引領整個IT世界在容器編排管理這個領域裏傲遊的舵手和領導者地位的體現。數據庫
再回到SAP,做爲一家向雲轉型的軟件公司,據Jerry所知目前SAP內部不少開發團隊的持續集成/持續交付的流程和系統已經遷移到Kubernetes上,受益於Kubernetes高度的自動化和高可用性,SAP基於微服務架構的產品開發團隊的交付流程大大簡化,同時運維人員的工做量也大大減輕。伴隨着SAP內部對Kubernetes的使用,也誕生了一位位像**Jason Gu,Benny Gu和Peng Wang(排名不分前後)**這樣的Kubernetes技術專家。編程
Kubernetes只用於SAP內部麼?固然不是。Jerry以前的文章曾經介紹過SAP雲平臺上的Neo和CloudFoundry編程環境:跨域
現在(2018年11月),打開SAP雲平臺官網,會發現這樣一條新聞:架構
https://cloudplatform.sap.com/enterprise-paas/kubernetes.html框架
按照網頁上提供的信息,Kubernetes在將來也會成爲SAP雲平臺支持的運行環境之一。SAP Partners們之前部署並運行在Kubernetes容器集羣上的應用,經過另外一個開源工具,Gardener,能夠容易地遷移到SAP雲平臺的Kubernetes環境下。
Gardener的首頁也頗有意思,口號是「The Kubernetes Botanist」,Jerry用過Gardener提供的一站式服務建立用於試用目的的Kubernetes集羣,以爲確實很是方便,其簡捷的步驟爲應用軟件開發人員屏蔽了Kubernetes集羣底層搭建和配置細節,可以在短短几分鐘內獲得一個可用的Kubernetes集羣:
這種Kubernetes-As-A-Service的特色,正和其口號裏的"Botanist"相吻合,Gardener就像一位辛勤的園丁,在全球的Kubernetes初學者的laptop上播下了一顆顆Kubernetes集羣的種子。
除了SAP內部產品產品的持續集成和持續交付已經在使用Kubernetes,SAP雲平臺將會添加對Kubernetes的支持以外,據Jerry所知,至少還有一個SAP發佈的產品是基於Kubernetes的,那就是Kyma。
小的時候,Jerry聽過牛頓這樣謙虛的一句話:「若是說我看得比別人更遠些,那是由於我站在巨人的肩膀上。(If I have seen further, it is by standing on the shoulders of giants.)」。當時聽了也就聽了。今年上半年,我是在對Kubernetes一無所知的前提下接觸了Kyma,當時以爲一頭霧水。等聽了SAP上海研究院三位老師的Kubernetes培訓課程以後,再回過頭來看Kyma,突然有點領悟到牛頓當年這句話的含義。
Kyma是什麼? 又雙叒叕一個SAP開源的項目,源自希臘語,意思是wave(水波,波濤,注意下圖Kyma官網的水波logo吧,囧),Jerry我的揣測,這意味着SAP但願憑藉Kyma,在本就風起雲涌的雲原生開發世界裏再掀波瀾?
根據Kyma官網的描述,Kyma是一個基於Kubernetes的企業軟件擴展平臺,能以Serverless/微服務架構的方式對On-premise或者雲應用進行擴展。
當您在閱讀不少SAP C/4HANA的宣傳資料時,好比下圖對SAP C/4HANA五朵雲的介紹,會看到另外一個名詞,SAP Cloud Platform Extension Factory(SAP雲平臺擴展工廠)。Kyma和SAP Cloud Platform Extension Factory的關係,恰如Open UI5和Fiori的關係。Open UI5是SAP推出的一個開源UI開發框架和UI控件庫,而Fiori是SAP 基於Open UI5這個技術框架開發出來的商業化產品(固然如今Fiori也表明SAP推薦的一種UI風格)。相似的,SAP Cloud Platform Extension Factory是SAP基於Kyma這個開源項目,再針對企業應用所必須知足的一些標準(好比SAP產品標準,區域特殊需求)而添加進額外的附加功能和實現的商用產品。
Jerry目前工做的團隊隸屬於SAP客戶體驗(Customer Experience)部門,這個部門的CTO Moritz Zimmermann, 在他的linkedin上發表過一篇博客,裏面也提到了Kyma:
https://www.linkedin.com/pulse/yaas-turns-sap-cp-extension-factory-bringing-digital-level-moritz/
也正是在這篇博客裏,Mortiz給出了一個重要的指示:Kyma(SAP Cloud Platform Extension Factory)未來會成爲SAP C/4HANA套件裏全部基於微服務架構產品的統一擴展工具。
Kyma到底有什麼強大之處,可以同時知足SAP C/4HANA裏五朵雲的擴展需求?咱們來看看Kyma的官方網站是怎麼說的:
做爲一個開發人員,上面這段Kyma的介紹文字,最吸引個人莫過於Jerry高亮的「Kyma可以容許開發人員使用任何技術棧去擴展應用,這些技術棧能夠和被擴展的原始應用沒有任何關係」。
那麼Kyma的工做原理究竟是怎樣的?咱們用一個具體例子來講明。
因爲到目前爲止出現了不少新名詞:容器,Kubernetes,Gardener,Kyma等等,在Netweaver上作二次開發的partner們可能以爲很陌生,因此這裏咱們選擇一個熟悉的場景做爲例子。
假設有這樣一個數據同步的需求:每當SAP Cloud for Customer(C4C)裏有銷售訂單建立或者修改時,把該訂單同步到S/4HANA去。
對於這種多個SAP產品間的數據同步需求,SAP推薦的解決方案是使用SAP PI或者SAP HANA Cloud Integration做爲數據同步的中間件。
由於本文是談Kyma,因此Jerry介紹第三種解決方案。
C4C系統提供一個所謂OData事件通知機制:
下圖配置頁面含義是爲銷售訂單這個Business Object的Create和Update兩個事件定義發佈機制:一旦有新的銷售訂單生成或者已經存在的銷售訂單被修改,C4C會經過我定義的OData服務zjerrysalesorder自動向這兩個事件的監聽者發佈事件。
事件的監聽者,或者說消費者,在下面的界面註冊。我在S/4HANA系統,A6P/213開發了一個Restful API,負責接收C4C系統發佈的銷售訂單事件,根據C4C Odata提供的數據在S/4HANA建立銷售訂單。這是另外一種輕量級的數據同步解決方案。
這種解決方案的核心就是發佈者/訂閱者模式。其實這也正是Kyma的擴展原理。
1. 經過Application Connector,可使Kyma同SAP C/4HANA的產品創建鏈接,而後進行事件註冊。
2. 事件註冊好以後,使用微服務架構實現事件的監聽者(消費者)。這也是Kyma官網裏提到的"開發者可使用任何技術棧進行擴展開發「的含義。舉個例子,咱們在SAP Commerce Cloud裏建立一個訂單後,客戶提出了基於該企業流程的一些特殊校驗邏輯。Commerce Cloud發佈一個"Order Create"的事件,事件payload包含建立訂單的字段。咱們開發並部署在Kyma上的微服務監聽這個事件,微服務內部實現能夠採起任何技術棧,Commerce Cloud經過HTTP調用包含了企業自定義訂單校驗邏輯的微服務,根據其返回的校驗結果進行後續處理。
經過這種方式,實現了進行二次開發的Kyma微服務同SAP標準產品的解耦。咱們能夠同ABAP Netweaver裏傳統的流程擴展手段**Business Addin(****BAdI)**進行比較,後者也能實現加強邏輯和標準產品的解耦,只不過BAdI加強和SAP標準邏輯是運行在同一臺物理機的同一個ABAP session內的。而Kyma這種加強方式,標準產品經過HTTP調用去消費部署在Kyma上的包含加強邏輯的微服務,雖然增長了網絡調用的開銷,可是能享受到Kyma底層的Kubernetes帶來的Servless特性,不用花費額外的工做量就能確保擴展的高可用性,節點處理能力的高擴展性和高伸縮性。
3. 爲了確保應用開發人員能真正專一於加強邏輯的開發,Kyma還引入了Lambda函數的概念。使用過JavaScript ES6的箭頭函數和Java 8的Lambda表達式,函數接口的朋友們對這個概念必定不會陌生。
使用Kyma Lambda函數,應用開發人員不須要從頭實現一個微服務,Kyma會自動將SAP標準產品發佈的事件和上下文經過輸入參數注入到Lambda函數中,全部的加強邏輯均是如今Lambda函數內。
下圖上半部分是Kyma內的一個Lambda函數,基於nodejs實現,下半部分是徹底等價的ABAP SICF服務實現, Kyma中的event.extensions.request和response分別對應ABAP裏的server->request和server->response。
Lambda函數調用好以後,能夠直接做爲消費者綁定到某個事件上,被Kyma的Event Bus模塊觸發來實現對SAP產品的加強。固然,由於Kyma是基於Kubernetes,咱們也能夠直接用kubectl create -f <yaml file>建立service,而後綁定到某個事件上,或者能夠藉助Service Broker導入第三方的service進行消費。
但願本文能讓你們對Kubernetes和SAP Kyma的關係從概念上有一個瞭解,感謝閱讀。
更多閱讀
SAP Cloud Platform Kubernetes Environment:
https://cloudplatform.sap.com/enterprise-paas/kubernetes.html
要獲取更多Jerry的原創文章,請關注公衆號"汪子熙":