十分鐘搭建自己Kubernetes集群 Ubuntu 20.04&containerd&calico

小明說(shuō):我只想搭建一個(gè)集群,網(wǎng)上搜出一大堆原理內(nèi)容,還分了好幾篇看的我眼花繚亂。波波help

波波說(shuō):好,沒(méi)關(guān)系。今天咱們一起來(lái)搭一個(gè)集群。廢話不多說(shuō)開(kāi)干!

環(huán)境要求

每臺(tái)機(jī)器 2 GB 或更多的 RAM 2 CPU 核或更多


準(zhǔn)備工作


? ? ?內(nèi)核確認(rèn)

uname -a

Linux k8s-node2 5.4.0-96-generic #109-Ubuntu SMP Wed Jan 12 16:49:16 UTC 2022 x86_64 x86_64 x86_64 GNU/Linux

? ? ? 設(shè)定IP

cd /etc/netplan/

sudo mv 00-installer-config.yaml 00-installer-config.yaml.disabled


vi 99-installer-config.yaml

network:

? version: 2

? ethernets:

? ? ens33:

? ? ? dhcp4: no

? ? ? addresses: [192.168.88.100/24]

? ? ? gateway4: 192.168.88.2

? ? ? nameservers:

? ? ? ? ? addresses: [192.168.88.2]

? ? ? ? ? search: []

? ? ? optional: true

netplan apply

我準(zhǔn)備了三臺(tái)機(jī)器

master:192.168.88.100

node1:192.168.88.101

node2:192.168.88.102

? ? ? ?關(guān)閉swap

vi? /etc/fstab 注釋掉最后一行

swapoff -a && swapon -a

free -m 查看


kubeadm安裝集群

模塊配置

cat <<EOF | sudo tee /etc/modules-load.d/k8s.conf

br_netfilter

EOF

cat <<EOF | sudo tee /etc/sysctl.d/k8s.conf

net.bridge.bridge-nf-call-ip6tables = 1

net.bridge.bridge-nf-call-iptables = 1

net.ipv4.ip_forward = 1

EOF

sudo sysctl --system

sudo apt-get install -y apt-transport-https ca-certificates curl

安裝containerd

apt-get install containerd

容器運(yùn)行時(shí)

cat <<EOF | sudo tee /etc/modules-load.d/containerd.conf

overlay

br_netfilter

EOF

sudo modprobe overlay

sudo modprobe br_netfilter

cat <<EOF | sudo tee /etc/sysctl.d/99-kubernetes-cri.conf

net.bridge.bridge-nf-call-iptables? = 1

net.ipv4.ip_forward? ? ? ? ? ? ? ? = 1

net.bridge.bridge-nf-call-ip6tables = 1

EOF

sudo sysctl --system

sudo mkdir -p /etc/containerd

containerd config default | sudo tee /etc/containerd/config.toml

sudo systemctl restart containerd


配置crictl?

VERSION="v1.23.0"

wget https://github.com/kubernetes-sigs/cri-tools/releases/download/$VERSION/crictl-$VERSION-linux-amd64.tar.gz

sudo tar zxvf crictl-$VERSION-linux-amd64.tar.gz -C /usr/local/bin

rm -f crictl-$VERSION-linux-amd64.tar.gz

vi /etc/crictl.yaml

runtime-endpoint: unix:///var/run/containerd/containerd.sock

image-endpoint: unix:///var/run/containerd/containerd.sock

timeout: 2

debug: false

pull-image-on-create: false


安裝kubeadm

更新?apt?包索引并安裝使用 Kubernetes?apt?倉(cāng)庫(kù)所需要的包:

sudo apt-get update

sudo apt-get install -y apt-transport-https ca-certificates curl

下載 Google Cloud 公開(kāi)簽名秘鑰:

sudo curl -fsSLo /usr/share/keyrings/kubernetes-archive-keyring.gpg https://packages.cloud.google.com/apt/doc/apt-key.gpg

添加 Kubernetes?apt?倉(cāng)庫(kù):

echo "deb [signed-by=/usr/share/keyrings/kubernetes-archive-keyring.gpg] https://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee /etc/apt/sources.list.d/kubernetes.list

更新?apt?包索引,安裝 kubelet、kubeadm 和 kubectl,并鎖定其版本:

sudo apt-get update

sudo apt-get install -y kubelet kubeadm kubectl

sudo apt-mark hold kubelet kubeadm kubectl


注意:以上master與node都要安裝


安裝 kubeadm

kubeadm init --apiserver-advertise-address=192.168.88.100 \

? ? ? ? ? ? --service-cidr=10.1.0.0/16 \

? ? ? ? ? ? --pod-network-cidr=192.168.0.0/16


--apiserver-advertise-address?可用于為控制平面節(jié)點(diǎn)的 API server 設(shè)置廣播地址。

--control-plane-endpoint?可用于為所有控制平面節(jié)點(diǎn)設(shè)置共享端點(diǎn)。

--control-plane-endpoint?允許 IP 地址和可以映射到 IP 地址的 DNS 名稱。 (calico默認(rèn)是192.168.0.0)

安裝完后按照說(shuō)明執(zhí)行

? mkdir -p $HOME/.kube

? sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config

? sudo chown $(id -u):$(id -g) $HOME/.kube/config

有幾個(gè)node就你的節(jié)點(diǎn)中粘貼執(zhí)行即可

kubeadm join 192.168.88.100:6443 --token osgyk1.ewoygvudbb84xk3l \

? ? ? ? --discovery-token-ca-cert-hash sha256:4c17899291da6c9888c1f5f02454bcf471a4a3ae214dbe85f2178953456665c1

這個(gè)比較關(guān)節(jié)

export KUBECONFIG=/etc/kubernetes/admin.conf >> ~/.bash_profile

source ~/.bash_profile

順利完成

常見(jiàn)問(wèn)題

1,kubeadm安裝不成功 查看日志,有可能是API server 設(shè)置廣播地址寫(xiě)錯(cuò)了

2,kubeadm join的命令不小心丟了怎么辦?

? ? ? kubeadm token create --print-join-command重新生成一下。

3,搞砸了怎么辦?

給你四個(gè)我的寶貝,然后重新安裝。

kubeadm reset

rm -rf /etc/cni/net.d

rm -rf $HOME/.kube/config

rm -rf /etc/kubernetes/


小明你學(xué)會(huì)了嗎?

總結(jié):其實(shí)最好的教程就是官網(wǎng)的幫助文檔。K8s安裝的東西稍多了一些,我只是梳理了一下。便于小伙伴們理解。

參考:

安裝 kubeadm

安裝containerd

配置crictl

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,363評(píng)論 6 532
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,497評(píng)論 3 416
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 176,305評(píng)論 0 374
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 62,962評(píng)論 1 311
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,727評(píng)論 6 410
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 55,193評(píng)論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,257評(píng)論 3 441
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 42,411評(píng)論 0 288
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,945評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,777評(píng)論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,978評(píng)論 1 369
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,519評(píng)論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,216評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 34,642評(píng)論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 35,878評(píng)論 1 286
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,657評(píng)論 3 391
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,960評(píng)論 2 373

推薦閱讀更多精彩內(nèi)容