真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

阿里巴巴如何改善開發(fā)人員在K8s上的體驗?

阿里巴巴如何改善開發(fā)人員在 K8s 上的體驗?

作者:鄧洪超 阿里巴巴應用交付專家

創(chuàng)新互聯(lián)長期為1000多家客戶提供的網(wǎng)站建設服務,團隊從業(yè)經(jīng)驗10年,關注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為海滄企業(yè)提供專業(yè)的成都網(wǎng)站設計、成都做網(wǎng)站、外貿(mào)網(wǎng)站建設,海滄網(wǎng)站改版等技術服務。擁有十載豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。

前言

通過 K8s,用戶能夠自定義基礎設施,可以平行的替換或改造平臺的已有功能,而非只能局限在平臺提供的能力之上構建。但正是這樣的“白盒化”體驗,正在為越來越多的研發(fā)和運維帶來“太復雜”的困擾。

從 Kubernetes 到“以應用為中心”的美好未來之間,全世界的 PaaS 工程師其實都在期待一項全新的技術能夠彌補這之間的鴻溝。阿里云原生應用平臺團隊的做法是,通過為應用“建?!钡姆绞絹斫鉀Q這個問題,這也正是 Open Application Model (OAM) 開源項目得以創(chuàng)建的重要目的。

阿里巴巴的容器化之旅

阿里巴巴如何改善開發(fā)人員在 K8s 上的體驗?

阿里巴巴的容器化之旅始于 2013 年。在 Docker 誕生之前,阿里巴巴基于 lxc 的容器引擎研發(fā)了容器技術 T4,用于在裸機上部署和管理應用程序。

2017 年, 阿里巴巴內(nèi)部孵化了類似于 K8s 的容器編排引擎 Sigma 作為資源統(tǒng)一層,用于管理內(nèi)部機器池,平均利用率達到 40%。

2018 年,Sigma 重新設計并遷移成兼容 K8s API,阿里巴巴重新編寫了自定義控制器和調(diào)度算法,并向暴露聲明式 API 給用戶試用。

2019 年底,阿里巴巴中的大多數(shù)應用都在 K8s 上運行,并且在 K8s 之上構建了數(shù)十個原生框架,構筑 K8s 生態(tài)系統(tǒng)。而 2019 年的 雙11 活動不僅僅是商業(yè)上的成功,更是 K8s 基礎設施可以支持如此大規(guī)模的有力證明。

在解決了 K8s 中的規(guī)模化和穩(wěn)定性問題之后,我們開始面臨一個新的挑戰(zhàn):K8s API 過于復雜,開發(fā)人員很難學習。

導致 K8s API 復雜的 3 個原因

K8s API 之所以復雜,主要有以下三個主要原因:

1. K8s 缺乏以“應用”為中心的資源模型

K8s 中沒有“應用”的概念,只有松散耦合的基礎架構資源。部署應用需要編寫 Pod、設置網(wǎng)絡和存儲之類的基礎設施資源,非常底層。然而,對于開發(fā)人員來說,他們不想配置這些復雜的底層資源信息,他們想從開發(fā)層面指定應用部署規(guī)范,例如具有自動擴容、監(jiān)控、Ingress 等功能的無狀態(tài)服務組件。我們需要提供更高層級的應用層抽象和以應用程序為中心的資源模型,以彌合部署應用程序和配置之間的差距。

阿里巴巴如何改善開發(fā)人員在 K8s 上的體驗?

2. K8s API 中沒有分離開發(fā)和運維的關注點

其次,K8s API 中沒有分離開發(fā)和運維的關注點。從上圖可以看出,K8s 將所有屬于不同角色的字段封裝在一個 API 中。例如,開發(fā)人員僅需指定容器映像、端口和運行狀況檢查;運維人員則負責配置副本大小、滾動更新策略、存儲卷訪問模式等。

對于 K8s API 來說這樣的聲明是沒有問題的。K8s 意在公開基礎架構功能,并用于構建其他平臺。因此,它需要包含所有內(nèi)容,并提供多合一的 API。但是,我們發(fā)現(xiàn)多合一 API 不適合寫應用程序的終端用戶。在 K8s API 之上,我們需要區(qū)分角色、將開發(fā)和運維的關注點分離開。

3. 在 K8s 上沒有可移植的應用抽象定義

K8s 定義了使用基礎資源的標準方法。但是如上所述,部署應用程序需要網(wǎng)絡接入、監(jiān)控、日志等。我們需要對那些應用程序操作接口進行標準化,實現(xiàn)可移植的應用層抽象。

OAM 開啟下一代云原生 DevOps 技術革命

針對上述 K8s API 過于復雜、開發(fā)人員難學習的問題,這里來介紹一下由阿里巴巴聯(lián)合微軟在社區(qū)推出的用于構建和交付云原生應用的標準規(guī)范 — 開放應用程序模型 OAM(Open Application Model)。

阿里巴巴如何改善開發(fā)人員在 K8s 上的體驗?

2019 年 10 月,阿里巴巴宣布聯(lián)合微軟共同推出 開放應用模型項目(Open Application Model - OAM)。

所謂“應用模型”,其實是一個專門用來對云原生應用本身和它所需運維能力進行定義與描述的標準開源規(guī)范。所以對于 Kubernetes 來說,OAM 即是一個標準的“應用定義”項目(類比已經(jīng)不再活躍的 Kubernetes Application CRD 項目),同時也是一個專注于封裝、組織和管理 Kubernetes 中各種“運維能力”、以及連接“運維能力”與“應用”的平臺層項目。

阿里巴巴如何改善開發(fā)人員在 K8s 上的體驗?

在 OAM 中,一個應用程序包含三個核心理念:
第一個核心理念是組成應用程序的服務組件(Component),它包含微服務、數(shù)據(jù)庫、云服務等;
第二個核心理念是描述應用程序運維特征(Trait)的集合,例如,彈性伸縮和 Ingress 等功能。它們對應用程序的運行至關重要,但在不同環(huán)境中其實現(xiàn)方式各不相同;
最后,為了將這些描述轉化為具體的應用實例,運維人員使用應用配置(Application Configuration)來組合組件和相應的特征,以構建可部署的應用交付實例。

如上圖所示,我們可以看到開發(fā)人員定義了組件 (Component) 來描述服務單元。然后運維人員定義運維特征 (Trait),并將其附加到前面的組件上,最后構成 OAM 可交付物 — ApplicationConfiguration。在圖中最下方,底層的基礎設施資源將通過 OAM 平臺呈現(xiàn)。

阿里巴巴如何改善開發(fā)人員在 K8s 上的體驗?

那么 OAM 如何解決上述三個 Kuberntes API 的問題?首先,OAM 隱藏了底層基礎架構細節(jié)(例如,是云還是物聯(lián)網(wǎng)),專注于應用層抽象,提供以應用為中心的資源模型。其次,OAM 劃分了應用交付路徑上的開發(fā)、運維、基礎架構三種角色,分離了關注點,讓流程更加清晰和易于管理。第三,K8s 定義了基礎架構的可移植抽象,而 OAM 站在 K8s 的肩膀上,提供了可移植的應用層抽象,讓同一個應用可以跨平臺運行。

OAM 還定義了一組核心工作負載/運維特征/應用范疇,作為應用程序交付平臺的基石。并且,這些核心規(guī)范有一個 開源實現(xiàn) — Crossplane。Crossplane 提供了讓用戶擴展其功能的機制。例如 Crossplane core 提供的 ContainerizedWorkload,在容器中運行應用程序并管理應用程序的生命周期。
此外,我們還可以添加更多工作負載(例如 FaaS)以運行無服務器功能,或者添加運維特性(例如 CronHPA)來定義 CronJob 類型的 HPA 策略。OAM 以標準的聲明方式在單個平臺中管理應用交付能力和流程。當模塊化的 Workload 和 Trait 越來越多,就會形成組件市場。而 OAM 就像是這個組件市場的管理者,處理組件之間的關系,把許多組件集成起來變成一個產(chǎn)品交付給用戶。OAM 加持下的 PaaS,可以像樂高積木一樣靈活組裝底層能力、運維特征、以及開發(fā)組件。使得應用管理變得統(tǒng)一,功能卻更加強大!

結語

以上我們討論了 OAM 的背景、動機和架構細節(jié)。值得注意的是,OAM 項目是開源中立、由社區(qū)驅動的。該規(guī)范和實現(xiàn)得到包括 Alibaba、Microsoft、Upbound 在內(nèi)的開放社區(qū)的支持。我們歡迎更多的人參與其中,共同定義云原生應用交付的未來。

您可以在 github repos 上貢獻: https://github.com/oam-dev/spec
加入郵件列表: https://groups.google.com/forum/#!forum/oam-dev

加入社區(qū)周會: Bi-weekly, Tuesdays 10:30AM PST

加入釘釘討論群:

阿里巴巴如何改善開發(fā)人員在 K8s 上的體驗?

阿里巴巴如何改善開發(fā)人員在 K8s 上的體驗?

“ 阿里巴巴云原生關注微服務、Serverless、容器、Service Mesh 等技術領域、聚焦云原生流行技術趨勢、云原生大規(guī)模的落地實踐,做最懂云原生開發(fā)者的技術圈。”


本文標題:阿里巴巴如何改善開發(fā)人員在K8s上的體驗?
鏈接分享:http://weahome.cn/article/jpgjpd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部