溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在樹莓派上構(gòu)建多節(jié)點K8S集群

發(fā)布時間:2021-11-20 10:58:29 來源:億速云 閱讀:118 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹如何在樹莓派上構(gòu)建多節(jié)點K8S集群,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

前期準備

要創(chuàng)建本文中的Kubernetes集群,我們需要準備:

  • 至少一個樹莓派(帶有SD卡和電源適配器)

  • 以太網(wǎng)電纜

  • 將我們所有的樹莓派連接在一起的交換機或路由器

我將從網(wǎng)絡上安裝K3s,所以需要通過路由器訪問互聯(lián)網(wǎng)。

集群架構(gòu)

對于這一集群,我們將使用3個樹莓派。第一個樹莓派我把它命名為kmaster,并分配一個靜態(tài)IP 192.168.0.50(因為我的本地網(wǎng)絡是192.168.0.0/24)。第一個worker節(jié)點(也就是第二個Pi),我們稱它為knode1并分配IP 192.168.0.51。最后一個worker節(jié)點,我們稱它為knode2并分配IP 192.168.0.52。

當然如果你的網(wǎng)絡和我不一樣,可以使用你能夠獲得網(wǎng)絡IP。只要在本文使用IP的任何地方替換你自己的值即可。

為了不必再通過IP引用每個節(jié)點,我們將其主機名添加到PC上的/ etc / hosts文件中。

echo -e "192.168.0.50\tkmaster" | sudo tee -a /etc/hosts
echo -e "192.168.0.51\tknode1" | sudo tee -a /etc/hosts
echo -e "192.168.0.52\tknode2" | sudo tee -a /etc/hosts

安裝master節(jié)點

現(xiàn)在我們已經(jīng)準備好,可以開始安裝master節(jié)點。第一步,安裝最新的Raspbian鏡像。我之前寫過一篇詳細的文章介紹為什么需要最新的鏡像,感興趣的朋友可以在訪問鏈接查看:

https://carpie.net/articles/headless-pi-with-static-ip-wired-edition

接下來,開始安裝Raspbian,啟用SSH server,為kmaster設置主機名稱并分配靜態(tài)IP 192.168.0.50。

既然Raspbian已經(jīng)在master節(jié)點上安裝完畢,讓我們啟用我們的master Pi并通過ssh進入它:

ssh pi@kmaster

現(xiàn)在我們要準備安裝K3s。在master Pi上運行:

curl -sfL https://get.k3s.io | sh -

命令執(zhí)行完畢之后,我們就有了一個已經(jīng)設置好的單節(jié)點集群并且正在運行中!讓我們檢查一下。依舊是在這個Pi上,運行:

sudo kubectl get nodes

你應該看到類似以下內(nèi)容:

NAME     STATUS   ROLES    AGE    VERSIONkmaster  Ready    master   2m13s  v1.14.3-k3s.1

提取join token

我們想要添加一對worker節(jié)點。在這些節(jié)點上安裝K3s,我們需要一個join token。Join token存在于master節(jié)點的文件系統(tǒng)上。讓我們復制并將它保存在某個地方,稍后我們可以獲取它:

sudo cat /var/lib/rancher/k3s/server/node-token

安裝worker節(jié)點

為兩個worker節(jié)點獲取一些SD卡,并在每個節(jié)點上安裝Raspbian。對于其中一個,將主機名設置為knode1并分配IP 192.168.0.51。對于另一個,將主機名設置為knode2并分配IP 192.168.0.52?,F(xiàn)在,讓我們安裝K3s。

啟動你的第一個worker節(jié)點,并通過ssh進入它:

ssh pi@knode1

在這個Pi上,我們將像之前一樣安裝K3s,但我們將給安裝程序額外的參數(shù),讓它了解我們正在安裝一個worker節(jié)點并且要加入一個現(xiàn)有集群:

curl -sfL http://get.k3s.io | K3S_URL=https://192.168.0.50:6443 \
K3S_TOKEN=join_token_we_copied_earlier sh -

使用從上個部分提取出來的join token替換join_token_we_copied_earlier。為knode2重復這些步驟。

從我們的PC訪問集群

每當我們要檢查或修改集群時,都必須通過SSH到master節(jié)點來運行kubectl,這很煩人。因此,我們像將kubectl放在我們的PC上,但是首先讓我們從master節(jié)點獲取所需的配置信息。通過SSH進入kmaster,并運行:

sudo cat /etc/rancher/k3s/k3s.yaml

復制配置信息并返回到你的PC。為配置創(chuàng)建一個目錄:

mkdir ~/.kube

保存復制的配置為~/.kube/config?,F(xiàn)在編輯文件并更改:

server: https://localhost:6443

改為:

server: https://kmaster:6443

為了安全起見,請將文件的讀/寫權(quán)限限制為你自己:

chmod 600 ~/.kube/config

現(xiàn)在讓我們在我們的PC上安裝kubectl(如果你還沒有)。Kubernetes網(wǎng)站上有針對各種平臺執(zhí)行此操作的說明。由于我正在運行Linux Mint(一個Ubuntu衍生版本),因此我將在此處顯示Ubuntu的說明:

sudo apt update && sudo apt install -y apt-transport-https
curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add -
echo "deb https://apt.kubernetes.io/ kubernetes-xenial main" | \
sudo tee -a /etc/apt/sources.list.d/kubernetes.list
sudo apt update && sudo apt install kubectl

如果你還不熟悉,上述命令為Kubernetes添加了一個Debian倉庫,獲取其GPG密鑰以確保安全,然后更新軟件包列表并安裝kubectl?,F(xiàn)在,我將通過標準軟件更新機制獲得有關(guān)kubectl更新的通知。

現(xiàn)在我們可以從我們的PC檢查我們的集群,運行:

kubectl get nodes

你應該看到類似以下內(nèi)容:

NAME     STATUS  ROLES   AGE   VERSIONkmaster  Ready   master  12m   v1.14.3-k3s.1knode1   Ready   worker  103s  v1.14.3-k3s.1knode1   Ready   worker  103s  v1.14.3-k3s.1

Congratulations!你現(xiàn)在已經(jīng)有一個正在工作的3個節(jié)點的Kubernetes集群!

使用K3s的附加 bonus

如果你運行kubectl get pods --all-namespaces,你將看到一些Traefik的額外pod。Treafik是一個反向代理和負載均衡器,我們可以使用它從單個入口點將流量引導到我們的集群中。Kubernetes當然也可以安裝Traefik,但不是默認提供的。所以K3s中默認提供Traefik是一個非常棒的設計!

以上是“如何在樹莓派上構(gòu)建多節(jié)點K8S集群”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI