云集技術(shù)學(xué)社|容器技術(shù)和Docker介紹

1月20日,深信服大云售前專家YJ在信服云《云集技術(shù)學(xué)社》系列直播課上進(jìn)行了《容器技術(shù)和Docker介紹》的分享,詳細(xì)介紹了容器技術(shù)的發(fā)展、以Docker為代表的容器技術(shù)生態(tài)以及容器技術(shù)的應(yīng)用場景。以下是他分享內(nèi)容摘要,想要了解更多可以關(guān)注“深信服科技”公眾號觀看直播回放。

看點(diǎn)一:容器和Docker發(fā)展歷史

容器技術(shù)發(fā)展是從上世紀(jì)70年代開始,在算力飛速發(fā)展的背景下,科學(xué)家圍繞著如何提高資源利用率進(jìn)行研究,因此產(chǎn)生了最早的資源隔離技術(shù),如chroot。資源隔離技術(shù)持續(xù)發(fā)展到21世紀(jì)初期,Namespace、Cgroup等資源隔離技術(shù)加入Linux內(nèi)核,形成了內(nèi)核標(biāo)準(zhǔn)的LXC容器技術(shù)。

2010年前后,云計(jì)算逐步發(fā)展,共享經(jīng)濟(jì)和互聯(lián)網(wǎng)的趨勢越來越明顯,要求企業(yè)對客戶的需求能夠精準(zhǔn)把控和快速滿足,因此出現(xiàn)了敏捷迭代。在敏捷迭代的場景下,如果每次都需要工程師重復(fù)地去規(guī)劃底層資源的隔離,配額,環(huán)境配置等,整體流程就無法實(shí)現(xiàn)敏捷。

基于這些背景,一個(gè)叫做Solomon Hykes的工程師提出了現(xiàn)代化容器的解決方案,他把這些技術(shù)整合到一個(gè)開箱即用的軟件中,并且加入了諸多如用戶友好的管理界面、規(guī)?;芾?、存儲格式等功能,這些能力如今都成為了容器的標(biāo)準(zhǔn)能力。

2014到2017年,Google等頭部廠商先后開源圍繞容器生態(tài)的解決方案,并試圖掌握技術(shù)主導(dǎo)權(quán),由此分化出CNCF和OCI等不同的技術(shù)組織和標(biāo)準(zhǔn)。

2018年后,CNCF主導(dǎo)的容器生態(tài)獲得巨大成功,驅(qū)動了容器技術(shù)為基礎(chǔ)的新一代PaaS的發(fā)展,孵化出了如應(yīng)用開發(fā)運(yùn)維能力(DevOps),應(yīng)用架構(gòu)(微服務(wù)),無服務(wù)器架構(gòu)等領(lǐng)域的新方案。

以上就是容器技術(shù)大概的發(fā)展歷史。提起容器技術(shù)大家會聯(lián)想到Docker,其實(shí)容器技術(shù)并不特指Docker,但Docker在整個(gè)容器技術(shù)領(lǐng)域有著非常重要的作用,主要表現(xiàn)在三個(gè)方面:

一是Docker是容器技術(shù)的開創(chuàng)者,Docker在LXC的基礎(chǔ)上降低了容器技術(shù)使用的復(fù)雜度,提出了大規(guī)模使用的管理運(yùn)維方案。開創(chuàng)性提出了鏡像文件實(shí)現(xiàn)了應(yīng)用和運(yùn)行環(huán)境的“一次封裝到處運(yùn)行”,進(jìn)而又推動技術(shù)的普及度。

二是Docker是容器技術(shù)的推廣者,DockerHub鏡像倉庫構(gòu)建了基于鏡像的開發(fā)者社區(qū)和生態(tài),讓全球開發(fā)者都參與到生態(tài)建設(shè)和分享中來,為容器技術(shù)的普及做出了極大貢獻(xiàn),Docker也憑此獲得高速發(fā)展和領(lǐng)導(dǎo)者地位。

三是Docker是標(biāo)準(zhǔn)的推動者,Docker貢獻(xiàn)和領(lǐng)導(dǎo)了容器鏡像和運(yùn)行時(shí)的OCI標(biāo)準(zhǔn)制定,加速了容器技術(shù)的發(fā)展。同時(shí)還貢獻(xiàn)了containerd,參與了CRI標(biāo)準(zhǔn)制定,推動了容器生態(tài)和組織的發(fā)展,最終達(dá)到工業(yè)級應(yīng)用。

盡管近些年Docker在容器技術(shù)主導(dǎo)權(quán)的地位爭奪中發(fā)展不太樂觀,但Docker經(jīng)過十年經(jīng)營,在市場認(rèn)知度、學(xué)習(xí)資源的完善度、客戶應(yīng)用的成熟度等方面仍具有巨大優(yōu)勢,是了解容器發(fā)展歷史和技術(shù)的首推學(xué)習(xí)對象。

  看點(diǎn)二:Docker為代表的容器技術(shù)介紹

當(dāng)談?wù)揇ocker的時(shí)候,并不是談?wù)搯为?dú)的產(chǎn)品,而是Docker公司針對容器技術(shù)、管理和生態(tài)的一整套解決方案。

云集技術(shù)學(xué)社|容器技術(shù)和Docker介紹

Docker由RunC、Containerd、Docker Engine、Docker Compose、Docker Swarm等部分組成:

RunC(low-level)是一個(gè)輕量級的工具,用來運(yùn)行容器,也是標(biāo)準(zhǔn)化的產(chǎn)物,是在圍繞容器格式和對運(yùn)行時(shí)制定的一個(gè)開放的工業(yè)化標(biāo)準(zhǔn)。

Containerd(high-level)是容器虛擬化技術(shù),從Docker中剝離出來,形成開放容器接口(OCI)標(biāo)準(zhǔn)的一部分,起到承上啟下的作用,對上接受命令參數(shù)的內(nèi)容,對下調(diào)用RunC實(shí)際的操作容器服務(wù)。

Docker Engine是執(zhí)行Docker標(biāo)準(zhǔn)的后臺應(yīng)用程序(Dockerd),用來構(gòu)建鏡像,運(yùn)行容器,管理網(wǎng)絡(luò)和存儲等。它的API不遵循CRI標(biāo)準(zhǔn)。任何第三方平臺與其集成必須開發(fā)對接其接口(Docker-shim)。

Docker Compose是基于YAML規(guī)范使用腳本來定義和簡化多容器部署的工具。Docker Swarm是Docker集群管理平臺。

Docker的核心概念是鏡像,鏡像含有啟動Docker容器所需的文件系統(tǒng)結(jié)構(gòu)及內(nèi)容??梢哉f,鏡像是Docker設(shè)計(jì)精巧的、引爆容器技術(shù)的核彈。

鏡像有五個(gè)特性:一是封裝,Docker鏡像將應(yīng)用及其類庫,配置、環(huán)境等依賴全部打包緊耦合到一個(gè)文件實(shí)現(xiàn)應(yīng)用遷移,讓應(yīng)用到任意環(huán)境都可開箱并立即正常運(yùn)行。

二是分層,Docker鏡像由基礎(chǔ)層(base image)和應(yīng)用層構(gòu)成,而應(yīng)用層可以根據(jù)對底層的依賴程度,抽象出不同的基礎(chǔ)層。

三是共享,基于分層文件系統(tǒng),不同的層可以被共享和依賴,使得鏡像通過標(biāo)準(zhǔn)API操作進(jìn)行復(fù)制時(shí),只需要獲取數(shù)據(jù)不同的層即可,不需要所有依賴都被復(fù)制(底層依賴已經(jīng)存在情況下,會通過層的UUID進(jìn)行校驗(yàn))。

四是輕量,多個(gè)容器通過同一個(gè)鏡像創(chuàng)建時(shí),不需要對鏡像進(jìn)行復(fù)制(對比虛擬機(jī)),只需要將鏡像層掛載為只讀,然后再加上一個(gè)可讀寫層即可。

五是寫時(shí)復(fù)制,只有在可讀寫層的數(shù)據(jù)變化且需要保存寫入新的層的時(shí)候,Docker鏡像才會生成新的鏡像層。寫時(shí)復(fù)制與分層機(jī)制可以大大減少磁盤空間的占用和容器啟動時(shí)間。

Docker基于鏡像去創(chuàng)建容器的具體步驟是:首先將BaseImage內(nèi)容作為容器的rootfs以只讀方式掛載。然后Docker Daemon繼續(xù)解析鏡像的其它層,如ADD,ENV等信息,對容器的運(yùn)行時(shí)環(huán)境進(jìn)行初始化。初始化后Docker Daemon繼續(xù)解析鏡像文件,執(zhí)行CMD信息中的命令并執(zhí)行,使得容器進(jìn)入運(yùn)行態(tài)。

Docker在計(jì)算時(shí)會用到Namespace和Cgroup技術(shù),Docker會基于Namespace技術(shù)進(jìn)行包括網(wǎng)絡(luò)、文件系統(tǒng)和環(huán)境等在內(nèi)的資源隔離。Linux Cgroup就是Linux內(nèi)核中用來為進(jìn)程設(shè)置資源限制的一個(gè)重要功能,全稱是Linux Control Group,主要作用是限制一個(gè)進(jìn)程能夠使用的資源上限,包括CPU、內(nèi)存、磁盤、網(wǎng)絡(luò)帶寬等等。

鏡像倉庫是用來存儲和分發(fā)容器鏡像的應(yīng)用。企業(yè)和個(gè)人對產(chǎn)出的鏡像文件可以集中管理,便于進(jìn)行權(quán)限控制、安全控制、能力共享、生態(tài)建設(shè)等。鏡像倉庫可以對基于容器鏡像的應(yīng)用進(jìn)行統(tǒng)一的版本,分發(fā)管理等。鏡像倉庫可以簡化和優(yōu)化企業(yè)基于容器的開發(fā)測試管理和集成,運(yùn)維流程等(如CICD)。

看點(diǎn)三:容器其他重要概念與應(yīng)用場景

除了容器技術(shù)生態(tài)外,容器還有著其他的重要概念。Docker和虛擬機(jī)都是資源隔離的方案。Docker是基于OS的資源隔離技術(shù),Docker Engine占用資源很少,物理機(jī)資源基本上被容器應(yīng)用和物理機(jī)操作系統(tǒng)使用。虛擬機(jī)多了一層Guest OS(虛擬機(jī)操作系統(tǒng)),若一臺物理機(jī)上跑10臺虛擬機(jī),則有10個(gè)Guest OS的資源損耗,Hypervisor層虛擬化,降低了虛擬機(jī)性能。

云集技術(shù)學(xué)社|容器技術(shù)和Docker介紹

容器安全也是現(xiàn)在一個(gè)比較重要的領(lǐng)域,目前容器安全主要注重四個(gè)方面,一是鏡像安全,如果使用了不安全的外部鏡像依賴,鏡像中有系統(tǒng)漏洞、缺陷,或者被惡意植入病毒和后門等,都會對容器造成較大威脅。二是容器逃逸,由于容器是基于OS共享的架構(gòu),如果攻擊者利用容器漏洞,獲取OS root權(quán)限,文件系統(tǒng)權(quán)限等,都會對整個(gè)系統(tǒng)造成極大危害。三是配置安全,即對容器引擎,鏡像倉庫,Kubernetes等沒有進(jìn)行正確的權(quán)限配置等造成的入侵。四是漏洞管理,針對鏡像中的類庫文件漏洞,如apache log4j2漏洞,需要對鏡像文件進(jìn)行及時(shí)識別和更新。

容器技術(shù)在深入到企業(yè)級應(yīng)用時(shí),還要有巨大的知識需要掌握,比如管理調(diào)度、大規(guī)模網(wǎng)絡(luò)的網(wǎng)絡(luò)性能、容器日志運(yùn)行監(jiān)控等,這些都需要對相應(yīng)的解決方案進(jìn)行深入學(xué)習(xí)。另外,由于容器技術(shù)的特性和生態(tài)發(fā)展,云服務(wù)廠商也在普遍使用容器技術(shù)構(gòu)建企業(yè)級PaaS平臺。

容器的應(yīng)用場景主要有六個(gè):一是快速開發(fā),由于公有鏡像倉庫有著龐大的開源社區(qū)和開放的鏡像資源,可以讓開發(fā)者實(shí)現(xiàn)開箱即用。二是多云應(yīng)用,因?yàn)槿萜髋cIaaS解耦以及容器本身輕量的特性讓容器更便于去做多云的遷移。三是應(yīng)用隔離,在同一個(gè)服務(wù)器里需要運(yùn)行多個(gè)應(yīng)用時(shí),可以使用容器去做運(yùn)行環(huán)境和依賴的隔離。四是微服務(wù)架構(gòu),容器與微服務(wù)架構(gòu)輕量、敏捷彈性的特性適配。五是能力沉淀,利用容器技術(shù)可以將前期架構(gòu)的運(yùn)行環(huán)境封裝起來,方便后來的技術(shù)人員開箱即用,這也是對企業(yè)能力的沉淀。六是持續(xù)集成和部署,容器可以保障開發(fā)測試環(huán)境的一致性,實(shí)現(xiàn)快速迭代和部署。

以上就是本次直播的主要內(nèi)容。對云計(jì)算感興趣的IT朋友可以關(guān)注“深信服科技”公眾號回顧往期,了解更多云計(jì)算知識。

(免責(zé)聲明:本網(wǎng)站內(nèi)容主要來自原創(chuàng)、合作伙伴供稿和第三方自媒體作者投稿,凡在本網(wǎng)站出現(xiàn)的信息,均僅供參考。本網(wǎng)站將盡力確保所提供信息的準(zhǔn)確性及可靠性,但不保證有關(guān)資料的準(zhǔn)確性及可靠性,讀者在使用前請進(jìn)一步核實(shí),并對任何自主決定的行為負(fù)責(zé)。本網(wǎng)站對有關(guān)資料所引致的錯誤、不確或遺漏,概不負(fù)任何法律責(zé)任。
任何單位或個(gè)人認(rèn)為本網(wǎng)站中的網(wǎng)頁或鏈接內(nèi)容可能涉嫌侵犯其知識產(chǎn)權(quán)或存在不實(shí)內(nèi)容時(shí),應(yīng)及時(shí)向本網(wǎng)站提出書面權(quán)利通知或不實(shí)情況說明,并提供身份證明、權(quán)屬證明及詳細(xì)侵權(quán)或不實(shí)情況證明。本網(wǎng)站在收到上述法律文件后,將會依法盡快聯(lián)系相關(guān)文章源頭核實(shí),溝通刪除相關(guān)內(nèi)容或斷開相關(guān)鏈接。 )