如何快速搭建 Kubernetes 平臺環境
背景:
作為云原生時代的平臺的底層基石與資源管理器,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 的目的。
整個安裝過程,這個文件很關鍵。下一期,詳細講解這個文件的邏輯。
https://github.com/labring/sealos/blob/main/pkg/apply/processor/install.go#L49。
參考鏈接:
sealos : https://www.sealyun.com/docs/lifecycle-management/quick-start/。