純手工搭建k8s集群-序

初衷

自kubernetes(k8s)問世以來,環境安裝、部署困難就一直被業內吐槽,同時也把很多初學者擋在門外。國內綠色的網路環境更是讓k8s安裝困難如虎添翼。所以社區也湧現出很多專門用於部署k8s的項目,像使用ansible腳本方式的kubeasz,在github上已經有500多star。

不管是官方的kube-admin還是社區貢獻的部署方案都離不開這幾種方式:

  • 使用現成的二進位文件

直接從官方或其他第三方下載,就是k8s各個組件的可執行文件。拿來就可以直接運行了。不管是centos,ubuntu還是其他的linux發行版本,只要gcc編譯環境沒有太大的區別就可以直接運行的。使用較新的系統一般不會有什麼跨平台的問題。

  • 使用源碼編譯安裝

編譯結果也是各個組件的二進位文件,所以如果能直接下載到需要的二進位文件基本沒有什麼編譯的必要性了。

  • 使用鏡像的方式運行同樣一個功能使用二進位文件提供的服務,也可以選擇使用鏡像的方式。就像nginx,像mysql,我們可以使用安裝版,搞一個可執行文件運行起來,也可以使用它們的鏡像運行起來,提供同樣的服務。k8s也是一樣的道理,二進位文件提供的服務鏡像也一樣可以提供。

從上面的三種方式中其實使用鏡像是比較優雅的方案,容器的好處自然不用多說。但從初學者的角度來說容器的方案會顯得有些複雜,不那麼純粹,會有很多容器的配置文件以及關於類似二進位文件提供的服務如何在容器中提供的問題,容易跑偏。所以二進位的方式更適合初學者。

那有同學會問了,網上已經有很多二進位安裝的教程了,我為什麼還重複造輪子?確實,k8s的二進位安裝方式確實也有很多教程了,我在入門的時候也有去看過,主要有兩種教程,一種是傻瓜式,也叫一鍵式,運行一個命令,執行一個腳本,一切搞定(當然一般會遇到一些問題,需要自己想辦法解決^_^)。還有一種是複雜式,一步一步的所有東西都寫下來,照著走一遍,基本幾個小時就過去了(主要是k8s的認證授權部分太複雜),還不算你中間遇到的問題。正是出於我自己在入門時碰到的種種問題,讓我有了這個想法:做一個專門給初學者看的教程,讓他們既能把環境搭建好,還能順帶理解k8s的架構,理解認證授權,理解每個組件的配置和它們之間的關係。所以我把k8s拆分了,剝離了它的認證授權和服務發現,先從核心模塊入手,搭建好一個集群,然後練練手,再給集群添加認證授權。讓初學者更容易接受了理解。

下面是具體的安裝文檔:

純手工搭建k8s集群-(1)預先準備環境

純手工搭建k8s集群-(2)核心模塊部署

純手工搭建k8s集群-(3)認證授權和服務發現

作者: 劉果國

鏈接:imooc.com/article/detai

來源:慕課網

本文原創發佈於慕課網 ,轉載請註明出處,謝謝合作


推薦閱讀:

【有獎問答】當我們談論Java時,我們都談些什麼?

LinkedHashMap原理和底層實現

資料庫系列:oracle體系結構

Redis集群最佳實踐

Kotlin擴展函數與高階函數-實際應用

推薦閱讀:

《架構即未來》(壹)
ApsaraDB For SQL Server Multi-AZ 高可用版資料庫使用介紹
理解卷積神經網路的利器:9篇重要的深度學習論文(下)
戰狼:業務高速增長,如何保證系統高可用
Android開發轉型公司技術負責人是一種怎樣的體驗

TAG:雲計算 | Docker | 架構 |