如何快速搭建 Kubernetes 平台环境

云计算 云原生
本系列带领大家,总结下市面上的快速构建平台的工具,帮助大家快速搭建自己的私有Kubernetes平台。本文给大家介绍的是sealos。

背景:

作为云原生时代的平台的底层基石与资源管理器,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/。

责任编辑:姜华 来源: 今日头条
相关推荐

2021-07-16 09:51:21

kubernetes环境容器

2010-06-04 16:17:02

2009-09-23 15:19:35

互联网

2022-08-21 16:50:36

Kubeadm​Kubernetes

2019-07-04 13:10:53

Docker设计云计算

2020-04-01 11:11:35

Hadoop运行环境分布式

2020-11-20 08:15:40

Grafana + P

2021-05-07 09:31:33

KindK8s Operator

2011-08-30 16:22:00

MTK开发环境

2011-09-06 10:36:10

QT平台

2012-02-16 10:00:59

2021-11-18 09:46:24

ServerlessKubeless 阿里云

2015-10-26 10:14:13

Android开发环境robolectric

2020-06-18 14:20:52

零代码开发明道云

2021-02-03 10:39:32

Kubernetes容器边缘计算

2022-10-08 11:31:30

KubernetesShellRoot

2019-07-23 07:30:16

2015-01-05 14:16:16

DockerFig自动化容器编排

2018-03-12 16:48:18

微信

2013-02-18 10:40:55

点赞
收藏

51CTO技术栈公众号