天天看點

如何快速的搭建kubernetes平台環境(1)

作者:研道鸠摩智

背景:

作為雲原生時代的平台的底層基石與資料總管,kubnernetes在大中小企業都完成了實踐與落地。盡管很多公有雲都提供了,一鍵部署的服務,但是天下沒有免費的午餐。羊毛出在羊身上,是以快速搭建叢集還得靠自己。本系列帶領大家,總結下市面上的快速建構平台的工具,幫助大家快速搭建自己的私有kubernetes平台。本文給大家介紹的是sealos

sealos:

sealos一個簡單幹淨輕量級穩定的kubernetes安裝工具,使用簡單,指令操作即可。

  1. 下載下傳安裝
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           
  1. 一鍵安裝
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           

最後這次成功了!!!

如何快速的搭建kubernetes平台環境(1)

安裝成功

如何快速的搭建kubernetes平台環境(1)

所有pod狀态

  1. 一鍵安裝中間件

本文示範下它是如何安裝ingress-nginx的。可以看到就是一個指令

如何快速的搭建kubernetes平台環境(1)

一鍵安裝ingress-nginx

如何快速的搭建kubernetes平台環境(1)

運作日志

一鍵安裝背後的黑科技

我們以sealos run labring/ingress-nginx:4.1.0 指令為例子,看看這一鍵安裝ingress-nginx背後的原理。它分為以下幾步

  1. 從 Docker Hub 或者其他鏡像倉庫中拉取 labring/ingress-nginx:4.1.0 鏡像;
  2. 在目前機器上建立一個 Kubernetes 叢集(或者連接配接到已經存在的叢集);
  3. 在 Kubernetes 叢集中建立一個 Deployment 對象,其 using labring/ingress-nginx:4.1.0 鏡像,并指定一些其它參數,如 replicas(副本數)和 port(暴露端口)等;
  4. 建立一個 Service 對象,将其和 Deployment 關聯,用于服務發現和負載均衡。

通過以上步驟,sealos run labring/ingress-nginx:4.1.0 指令将一個 Deployment 和一個 Service 對象建立到 Kubernetes 叢集中,進而實作了在 Kubernetes 叢集中部署 ingress-nginx 的目的。

如何快速的搭建kubernetes平台環境(1)

1

如何快速的搭建kubernetes平台環境(1)

2

如何快速的搭建kubernetes平台環境(1)

3

如何快速的搭建kubernetes平台環境(1)

4

整個安裝過程,這個檔案很關鍵。下一期,詳細講解這個檔案的邏輯。

https://github.com/labring/sealos/blob/main/pkg/apply/processor/install.go#L49

參考連結:

sealos : https://www.sealyun.com/docs/lifecycle-management/quick-start/

繼續閱讀