深入理解邊緣計(jì)算:云 邊 端工作原理與源碼分析
定 價(jià):89 元
內(nèi)容簡(jiǎn)介這是一本從環(huán)境搭建、部署配置、系統(tǒng)架構(gòu)、工作原理、源碼分析、二次開發(fā)等維度系統(tǒng)講解如何打造協(xié)同的云、邊、端系統(tǒng)的著作。全書一共9章,邏輯上分為三大部分:第1部分 邊緣計(jì)算基礎(chǔ)(第1~2章)首先介紹了邊緣計(jì)算和邊緣計(jì)算系統(tǒng)的概念、組成、架構(gòu),以及邊緣計(jì)算系統(tǒng)的部署與管理;然后分別以Kubernetes、KubeEdge、EdgeX Foundry為例講解了云、邊、端的部署與配置。既給出了邊緣計(jì)算系統(tǒng)部署所需的自動(dòng)化腳本,又分析了應(yīng)用在云數(shù)據(jù)中心部署和以云、邊、端協(xié)同的方式部署的利弊。第二部分 工作原理(第3~6章)首先從整體上對(duì)邊緣計(jì)算系統(tǒng)的邏輯架構(gòu)進(jìn)行了介紹,然后從部署、配置、架構(gòu)等角度對(duì)分別云、邊、端的核心組件的工作原理進(jìn)行了深入解析。第三部分 源碼分析(第7~9章)云、邊、端的開源框架眾多,云部分選擇Kubernetes、邊部分選擇KubeEdge、端部分選擇EdgeX Foundry,首先詳細(xì)介紹了這3種開發(fā)框架的開發(fā)環(huán)境搭建和源碼的整體架構(gòu),然后對(duì)他們的核心組件的源碼進(jìn)行了深入分析,同時(shí)也對(duì)這3個(gè)框架的二次開發(fā)進(jìn)行了講解。
(1)作者權(quán)威:之江實(shí)驗(yàn)室助理研究員,資深邊緣計(jì)算工程師,經(jīng)驗(yàn)豐富。(2)內(nèi)容系統(tǒng):包含環(huán)境搭建、部署配置、系統(tǒng)架構(gòu)、工作原理、源碼分析、二次開發(fā)6個(gè)維度。(3)循序漸進(jìn):既有核心概念、環(huán)境搭建、部署配置、系統(tǒng)架構(gòu)等基礎(chǔ)知識(shí),也有工作原理、源碼分析、二次開發(fā)等高階知識(shí)。(4)針對(duì)性強(qiáng):圍繞Kubernetes、KubeEdge、EdgeX Foundry三個(gè)主流的云、邊、端開源實(shí)現(xiàn)進(jìn)行講解。(5)圖文并茂:言簡(jiǎn)意賅、條理性強(qiáng),包含大量架構(gòu)圖、原理圖和流程圖。
為何寫作本書隨著5G、AR/VR、高清視頻、自動(dòng)駕駛等新技術(shù)的興起,電信網(wǎng)絡(luò)正面臨實(shí)時(shí)計(jì)算能力、超低時(shí)延、超大帶寬等帶來(lái)的新的挑戰(zhàn)。而只有促進(jìn)邊緣計(jì)算產(chǎn)業(yè)發(fā)展,構(gòu)建健康的生態(tài)環(huán)境,才能使終端用戶獲得新技術(shù)帶來(lái)的極致體驗(yàn),以及更加豐富、安全、可靠的應(yīng)用。因此,近年來(lái)移動(dòng)運(yùn)營(yíng)商、網(wǎng)絡(luò)設(shè)備供應(yīng)商、應(yīng)用開發(fā)商、內(nèi)容提供商等紛紛加入移動(dòng)邊緣計(jì)算領(lǐng)域,促使這一技術(shù)快速發(fā)展。目前,很多研究機(jī)構(gòu)制定了針對(duì)邊緣計(jì)算的專項(xiàng)計(jì)劃,比如斯坦福大學(xué)的PlatformLab、卡內(nèi)基梅隆大學(xué)的Open Edge Computing基金會(huì)等;ヂ(lián)網(wǎng)企業(yè)也針對(duì)邊緣計(jì)算推出了相關(guān)產(chǎn)品,比如亞馬遜的AWS GreenGrass Core、微軟的Azure Functions on IoT Edge、阿里巴巴的Link Edge、百度的IoT Intelligent Edge。除此之外,全球范圍的各大通信運(yùn)營(yíng)商也都陸續(xù)發(fā)布了邊緣計(jì)算白皮書。邊緣計(jì)算得到了很多行業(yè)和組織的重視,但是目前市場(chǎng)上針對(duì)邊緣計(jì)算系統(tǒng)性分析的圖書還很少。于是,筆者萌生了寫一本書的想法,想從邊緣計(jì)算系統(tǒng)的部署切入,系統(tǒng)分析邊緣計(jì)算系統(tǒng)的云、邊、端的原理架構(gòu)和源碼。讀者對(duì)象云計(jì)算領(lǐng)域從業(yè)者邊緣計(jì)算領(lǐng)域從業(yè)者物聯(lián)網(wǎng)領(lǐng)域從業(yè)者應(yīng)用運(yùn)維、開發(fā)人員數(shù)據(jù)中心運(yùn)維人員在校計(jì)算機(jī)專業(yè)學(xué)生物聯(lián)網(wǎng)領(lǐng)域的科研人員本書特色邊緣計(jì)算的意義在于云、邊、端的協(xié)同,而不應(yīng)該將邊緣計(jì)算看作獨(dú)立于云計(jì)算的計(jì)算平臺(tái),甚至是云計(jì)算的對(duì)立面。目前,針對(duì)云、邊、端都有不止一種開源計(jì)算框架,但每種計(jì)算框架又各有其側(cè)重點(diǎn),在這種現(xiàn)狀下為云、邊、端各選一種比較合適的計(jì)算框架進(jìn)行集成,打造一套云、邊、端協(xié)同的邊緣計(jì)算系統(tǒng),并對(duì)該系統(tǒng)的部署方法、內(nèi)部原理和相關(guān)源碼進(jìn)行解析是有現(xiàn)實(shí)意義的。本書的云組成部分選擇Kubernetes,邊組成部分選擇KubeEdge,端組成部分選擇EdgeX Foundry,對(duì)云、邊、端各部分都進(jìn)行了從架構(gòu)到源碼的系統(tǒng)分析,內(nèi)容系統(tǒng)性強(qiáng),受眾群體廣,從在校計(jì)算機(jī)專業(yè)學(xué)生到云計(jì)算、邊緣計(jì)算和物聯(lián)網(wǎng)領(lǐng)域?qū)<遥伎梢詤⒖急緯?br />如何閱讀本書本書圍繞云、邊、端展開介紹,整體分為3篇。基礎(chǔ)篇(第1~2章)首先介紹邊緣計(jì)算概念、邊緣計(jì)算系統(tǒng)的具體組成,對(duì)邊緣計(jì)算系統(tǒng)中的相關(guān)概念進(jìn)行解析;然后給出邊緣計(jì)算系統(tǒng)所需的自動(dòng)化部署腳本,讀者可以根據(jù)腳本輕松地將邊緣計(jì)算系統(tǒng)整體框架部署起來(lái),并在其上進(jìn)行管理和部署應(yīng)用;后從管理終端設(shè)備應(yīng)用的部署方式入手,對(duì)比分析該應(yīng)用在云數(shù)據(jù)中心部署和以云、邊、端協(xié)同的方式部署的利弊,從而引出使用邊緣計(jì)算的必要性。原理篇(第3~6章)為了使讀者能夠?qū)吘売?jì)算系統(tǒng)有一個(gè)全面、深入的了解,本篇將組成邊緣計(jì)算系統(tǒng)的云、邊、端分開介紹,逐步部署,并對(duì)每部分的配置項(xiàng)進(jìn)行詳細(xì)說(shuō)明:云包括以系統(tǒng)進(jìn)程方式部署和以容器化方式部署兩種;邊由與云控制節(jié)點(diǎn)交互的部分和在邊緣管理負(fù)載的部分組成,與云控制節(jié)點(diǎn)交互的部分包括以系統(tǒng)進(jìn)程方式部署和以容器化方式部署兩種,在邊緣管理負(fù)載的部分只有以系統(tǒng)進(jìn)程方式部署一種;端包括以系統(tǒng)進(jìn)程方式部署和以容器化方式部署兩種。源碼分析篇(第7~9章)通過(guò)對(duì)邊緣計(jì)算系統(tǒng)部署和配置的詳細(xì)說(shuō)明,讀者對(duì)邊緣計(jì)算實(shí)踐的云、邊、端部分有了一個(gè)相對(duì)深入的了解,但還停留在各部分的具體組成組件和相關(guān)配置說(shuō)明層面。本篇會(huì)對(duì)組成邊緣計(jì)算系統(tǒng)的云、邊、端部分進(jìn)行源碼分析,并對(duì)每部分組件之間的邏輯關(guān)系進(jìn)行詳細(xì)說(shuō)明。勘誤和支持由于筆者水平有限,編寫時(shí)間倉(cāng)促,書中難免會(huì)出現(xiàn)一些錯(cuò)誤或者不準(zhǔn)確的地方,懇請(qǐng)讀者批評(píng)指正。為此,筆者特意創(chuàng)建了一個(gè)在線支持與應(yīng)急方案的釘釘群33905630(群號(hào)),你可以將書中的錯(cuò)誤發(fā)布在該微信群。同時(shí),如果你遇到任何問(wèn)題,也可以發(fā)送郵件到myedgecomputing@gmail.com,我將盡可能及時(shí)提供滿意的解答。如果你有更多寶貴的意見(jiàn),也歡迎發(fā)送郵件至該郵箱,期待你們的真摯反饋。致謝首先要感謝開源社區(qū),讓我有機(jī)會(huì)接觸、學(xué)習(xí)和分析Kubernetes、KubeEdge和EdgeX Foundry這些優(yōu)秀的軟件。感謝之江實(shí)驗(yàn)室,為我提供了一個(gè)良好的工作環(huán)境,還有齊全的實(shí)驗(yàn)設(shè)備。感謝浙江省重點(diǎn)研發(fā)計(jì)劃項(xiàng)目基于數(shù)字孿生的智慧高速公路交通流全時(shí)空管控關(guān)鍵技術(shù)及應(yīng)用示范,使得書中相關(guān)技術(shù)得到驗(yàn)證。感謝之江實(shí)驗(yàn)室的研究專家華煒老師,在本書的寫作過(guò)程中他從整體到具體細(xì)節(jié)都給予了筆者耐心的指導(dǎo)。感謝《深度實(shí)踐KVM》作者肖力老師和公眾號(hào)云技術(shù)的北極熊老師的引薦,在他們的努力下才促成了本書的合作與出版。感謝機(jī)械工業(yè)出版社華章公司的編輯楊福川老師和董惠芝老師,在這一年多的時(shí)間中他們始終支持我的寫作,他們的鼓勵(lì)和幫助引導(dǎo)我順利完成了全部書稿。后感謝家人的理解與支持,讓我可以在工作之余全身心地投入本書的寫作,并在迷惑時(shí)給予我信心和力量!
作者簡(jiǎn)介崔廣章之江實(shí)驗(yàn)室高級(jí)研究專員,資深云計(jì)算和邊緣計(jì)算技術(shù)工程師。從2014年接觸云計(jì)算以來(lái),參與過(guò)多個(gè)云計(jì)算生產(chǎn)項(xiàng)目,其中代表性的項(xiàng)目有基于OpenStack進(jìn)行定制開發(fā)的運(yùn)營(yíng)商私有云、政務(wù)云,基于開源容器云方案定制開發(fā)的面向運(yùn)營(yíng)商的數(shù)據(jù)中心操作系統(tǒng)(DCOS),2018年開始從事邊緣計(jì)算相關(guān)研究與開發(fā)。
前言基礎(chǔ)篇第1章 邊緣計(jì)算入門31.1 邊緣計(jì)算系統(tǒng)31.1.1 邊緣計(jì)算系統(tǒng)的組成31.1.2 概念解析61.2 邊緣計(jì)算的意義111.3 邊緣計(jì)算系統(tǒng)的部署與管理111.3.1 系統(tǒng)部署111.3.2 系統(tǒng)管理231.4 不同應(yīng)用部署方式的比較251.5 本章小結(jié)27第2章 云、邊、端的部署與配置292.1 邊緣計(jì)算整體架構(gòu)292.2 部署云部分Kubernetes312.2.1 Kubernetes相關(guān)的容器運(yùn)行時(shí)部署312.2.2 Kubernetes的學(xué)習(xí)環(huán)境部署342.2.3 Kubernetes的生產(chǎn)環(huán)境部署392.3 部署邊緣部分KubeEdge452.3.1 以系統(tǒng)進(jìn)程的方式部署KubeEdge452.3.2 以容器化的方式部署KubeEdge512.4 部署端部分EdgeX Foundry522.4.1 以系統(tǒng)進(jìn)程的方式部署EdgeX Foundry532.4.2 以容器化的方式部署EdgeX Foundry572.5 本章小結(jié)60原理篇第3章 邊緣計(jì)算系統(tǒng)邏輯架構(gòu)633.1 邊緣計(jì)算系統(tǒng)邏輯架構(gòu)簡(jiǎn)介633.2 云、邊協(xié)同643.3 邊、端協(xié)同653.4 云、邊、端協(xié)同683.5 本章小結(jié)68第4章 云部分原理解析714.1 整體架構(gòu)714.2 邏輯架構(gòu)724.3 控制流程744.3.1 集群基礎(chǔ)設(shè)施層面的資源的控制流程744.3.2 集群中應(yīng)用負(fù)載層面的資源的控制流程774.4 數(shù)據(jù)流814.4.1 集群內(nèi)應(yīng)用負(fù)載間的數(shù)據(jù)訪問(wèn)流814.4.2 集群外應(yīng)用到集群內(nèi)應(yīng)用負(fù)載的數(shù)據(jù)訪問(wèn)流864.5 資源調(diào)度884.5.1 資源調(diào)度流程884.5.2 資源調(diào)度算法和調(diào)度策略894.6 資源編排904.7 本章小結(jié)91第5章 邊緣部分原理解析935.1 KubeEdge的整體架構(gòu)935.2 與云交互的組件945.3 管理邊緣負(fù)載的組件965.4 與終端設(shè)備交互的組件975.5 云、邊協(xié)同985.6 設(shè)備管理模型1005.7 邊緣存儲(chǔ)和網(wǎng)絡(luò)資源1025.8 邊緣節(jié)點(diǎn)管理1035.8.1 以節(jié)點(diǎn)的形式管理邊緣計(jì)算資源1035.8.2 以獨(dú)立集群的形式管理邊緣計(jì)算資源1045.8.3 以多集群的形式管理邊緣計(jì)算資源1055.9 本章小結(jié)106第6章 端部分原理解析1076.1 整體架構(gòu)1076.2 設(shè)備服務(wù)層1086.3 核心服務(wù)層1106.4 支持服務(wù)層1156.5 導(dǎo)出服務(wù)層1196.6 安全組件1226.7 系統(tǒng)管理組件1226.8 本章小結(jié)123源碼分析篇第7章 云部分源碼分析1277.1 搭建開發(fā)環(huán)境1277.1.1 安裝Go和GoLand1277.1.2 安裝Git并下載Kubernetes源碼1307.1.3 Go Modules簡(jiǎn)介1307.1.4 下載Kubernetes的源碼依賴1317.2 Kubernetes源碼整體結(jié)構(gòu)分析1317.3 組件源碼分析1337.3.1 共用命令行工具庫(kù)Cobra1337.3.2 Kube-apiserver1367.3.3 Kube-controller-manager1407.3.4 Kube-scheduler1457.3.5 Kubelet1487.3.6 Kube-proxy1507.4 本章小結(jié)153第8章 邊緣部分源碼分析1558.1 搭建開發(fā)環(huán)境1558.2 源碼整體架構(gòu)分析1558.2.1 源碼目錄及組件源碼入口1558.2.2 組件中各功能模塊的共用框架和功能分析1608.3 組件源碼分析1668.3.1 配置文件讀取1668.3.2 CloudCore1728.3.3 EdgeCore之Edged1808.3.4 EdgeCore之DeviceTwin1898.3.5 EdgeCore之EdgeHub1958.3.6 EdgeCore之EventBus2028.3.7 EdgeCore之MataManager2068.3.8 EdgeCore之EdgeMesh2128.4 本章小結(jié)217第9章 端部分源碼分析2199.1 搭建開發(fā)環(huán)境2199.2 源碼整體架構(gòu)分析2199.3 組件源碼分析2209.3.1 Config-seed2219.3.2 Core-command2329.4 本章小結(jié)238