背景:
作為雲原生時代的平台的底層基石與資料總管,kubnernetes在大中小企業都完成了實踐與落地。盡管很多公有雲都提供了,一鍵部署的服務,但是天下沒有免費的午餐。羊毛出在羊身上,是以快速搭建叢集還得靠自己。本系列帶領大家,總結下市面上的快速建構平台的工具,幫助大家快速搭建自己的私有kubernetes平台。本文給大家介紹的是sealos
sealos:
sealos一個簡單幹淨輕量級穩定的kubernetes安裝工具,使用簡單,指令操作即可。
- 下載下傳安裝
curl -sfL https://raw.githubusercontent.com/labring/sealos/v4.2.0/scripts/install.sh | sh -s v4.2.0 labring/sealos
如果網速較慢,可以換成手動下載下傳的方式,當然手動下載下傳前,需要先看看本機的系統的架構,然後再選擇下載下傳amd64還是arm64的。
uname -m
傳回x86_64,表明是amd64的,是以我們通過下面指令下載下傳
wget https://github.com/labring/sealos/releases/download/v4.2.0/sealos_4.2.0_linux_amd64.tar.gz \
&& tar zxvf sealos_4.2.0_linux_amd64.tar.gz sealos && chmod +x sealos && mv sealos /usr/bin
- 一鍵安裝
sealos run labring/kubernetes:v1.25.0 labring/helm:v3.8.2 labring/calico:v3.24.1 \
--masters 192.168.64.2,192.168.64.22,192.168.64.20 \
--nodes 192.168.64.21,192.168.64.19 -p [your-ssh-passwd]
我們為了示範,僅用了一台機器,通過ifconfig指令得到内部位址172.21.0.4
[root@master0 k8s]# ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 172.21.0.4 netmask 255.255.240.0 broadcast 172.21.15.255
inet6 fe80::5054:ff:fefe:b928 prefixlen 64 scopeid 0x20<link>
ether 52:54:00:fe:b9:28 txqueuelen 1000 (Ethernet)
RX packets 96511 bytes 18836570 (17.9 MiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 77971 bytes 15111315 (14.4 MiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
然後運作下面指令安裝:
sealos run labring/kubernetes:v1.25.0 labring/helm:v3.8.2 labring/calico:v3.24.1 --masters 172.21.0.4
當然如果上面的指令出現下面的問題,需要手動把ip_forward設定成1
[ERROR FileContent--proc-sys-net-ipv4-ip_forward]: /proc/sys/net/ipv4/ip_forward contents are not set to 1
[preflight] If you know what you are doing, you can make a check non-fatal with `--ignore-preflight-errors=...`
To see the stack trace of this error execute with --v=5 or higher
2023-06-14T12:48:06 error Applied to cluster error: failed to init init master0 failed, error: exit status 1. Please clean and reinstall
Error: failed to init init master0 failed, error: exit status 1. Please clean and reinstall
設定ip_forward完成轉發
sudo vi /etc/sysctl.conf
net.ipv4.ip_forward=1
sudo sysctl -p
然後清理下之前失敗的安裝,隻要失敗,就運作下面指令,很友善,之後再次運作上面的sealos run
sealos reset
最後這次成功了!!!
安裝成功
所有pod狀态
- 一鍵安裝中間件
本文示範下它是如何安裝ingress-nginx的。可以看到就是一個指令
一鍵安裝ingress-nginx
運作日志
一鍵安裝背後的黑科技
我們以sealos run labring/ingress-nginx:4.1.0 指令為例子,看看這一鍵安裝ingress-nginx背後的原理。它分為以下幾步
- 從 Docker Hub 或者其他鏡像倉庫中拉取 labring/ingress-nginx:4.1.0 鏡像;
- 在目前機器上建立一個 Kubernetes 叢集(或者連接配接到已經存在的叢集);
- 在 Kubernetes 叢集中建立一個 Deployment 對象,其 using labring/ingress-nginx:4.1.0 鏡像,并指定一些其它參數,如 replicas(副本數)和 port(暴露端口)等;
- 建立一個 Service 對象,将其和 Deployment 關聯,用于服務發現和負載均衡。
通過以上步驟,sealos run labring/ingress-nginx:4.1.0 指令将一個 Deployment 和一個 Service 對象建立到 Kubernetes 叢集中,進而實作了在 Kubernetes 叢集中部署 ingress-nginx 的目的。
1
2
3
4
整個安裝過程,這個檔案很關鍵。下一期,詳細講解這個檔案的邏輯。
https://github.com/labring/sealos/blob/main/pkg/apply/processor/install.go#L49
參考連結:
sealos : https://www.sealyun.com/docs/lifecycle-management/quick-start/