kind快速创建k8s集群

1、包描述:

安装docker

        docker-20.10.17.tgz (docker 20.10.17安装包)

        https://download.csdn.net/download/u014094652/88663072

安装kubectl:

        kubectl.tar (kubectl安装包)

        https://download.csdn.net/download/u014094652/88663132

安装kind

        kind.tar(kind v0.11.1安装包)

        https://download.csdn.net/download/u014094652/88663138

安装k8s集群

        kindest-node.tar(Kind 预发布的镜像,安装k8s v1.21.1使用),这个镜像较大,这边就不放在csdn上啦,如果可以连外网的话可以直接执行安装命令,也可以到官网下载        

  • 2、 安装docker

2.1、为什么要安装docker?

要使用 Kind 的前提是提供一个 Docker 环境

2.2、离线安装docker流程

  • 上传我们下载好的 docker-20.10.17.tgz 到服务器上

  • 解压: tar -xf docker-20.10.17.tgz   

  • cd docker && cp * /usr/bin/

  • 创建一个docker.service文件,并放到/etc/systemd/system/docker.service目录下

执行下面命令:

cat > /etc/systemd/system/docker.service <<'EOF'

[Unit]

Description=Docker Application Container Engine

Documentation=https://docs.docker.com

After=network-online.target firewalld.service containerd.service

Wants=network-online.target

[Service]

Type=notify

# the default is not to use systemd for cgroups because the delegate issues still

# exists and systemd currently does not support the cgroup feature set required

# for containers run by docker

ExecStart=/usr/bin/dockerd

ExecReload=/bin/kill -s HUP $MAINPID

TimeoutSec=0

RestartSec=2

Restart=always

# Note that StartLimit* options were moved from "Service" to "Unit" in systemd 229.

# Both the old, and new location are accepted by systemd 229 and up, so using the old location

# to make them work for either version of systemd.

StartLimitBurst=3

# Note that StartLimitInterval was renamed to StartLimitIntervalSec in systemd 230.

# Both the old, and new name are accepted by systemd 230 and up, so using the old name to make

# this option work for either version of systemd.

StartLimitInterval=60s

# Having non-zero Limit*s causes performance problems due to accounting overhead

# in the kernel. We recommend using cgroups to do container-local accounting.

LimitNOFILE=infinity

LimitNPROC=infinity

LimitCORE=infinity

# Comment TasksMax if your systemd version does not support it.

# Only systemd 226 and above support this option.

TasksMax=infinity

# set delegate yes so that systemd does not reset the cgroups of docker containers

Delegate=yes

# kill only the docker process, not all processes in the cgroup

KillMode=process

OOMScoreAdjust=-500

[Install]

WantedBy=multi-user.target

EOF

  • 将docker做成系统服务,并设置开机自启

    

chmod +x  /etc/systemd/system/docker.service

systemctl daemon-reload

systemctl enable  docker.service

systemctl start    docker.service

systemctl status   docker.service

docker服务起来则代表安装完成!

注意:设置加速镜像,不过我们内部虚拟机无法访问外网,所以不需要了

  • 3、安装kubectl

3.1、为什么要安装kubectl?

Docker 安装过后接下来可以安装一个 kubectl 工具,Kind 本身不需要 kubectl,安装 kubectl 可以在本机直接管理 Kubernetes 集群。不然无法操作 kubectl 等相关命令

3.2、kubectl学习网址

Install Tools | Kubernetes

3.3、离线安装kubectl流程

        解压提供的kubectl.tar包:tar -xvf kubectl.tar

        使kubectl二进制可执行文件:chmod +x ./kubectl

        将二进制文件移到您的PATH中:mv ./kubectl /usr/local/bin

        测试安装版本:kubectl version

出现版本安装完成!

  • 4、 安装kind

4.1、背景

Kind 是 Kubernetes in Docker 的简写,是一个使用 Docker 容器作为 Node 节点,在本地创建和运行Kubernetes 集群的工具。适用于在本机创建 Kubernetes 集群环境进行开发和测试。使用 Kind 搭建的集群无法在生产中使用,但是如果你只是想在本地简单的玩玩 K8s,不想占用太多的资源,那么使用 Kind 是你不错的选择

4.2、架构

Kind 的架构图如下所示,它将 Docker 容器作为 Kubernetes 的 Node 节点,并在该 Node 中安装 Kubernetes组件,包括一个或者多个 Control Plane 和一个或者多个 Work Nodes。这就解决了在本机运行多个 Node 的问题,而不需要虚拟化。

4.3、学习地址 

kind – Quick Start

4.4、离线安装kind过程

        解压kind安装包:tar -xvf kind.tar

        kind添加可执行权限:chmod +x kind

        kind命令放在/usr/local/bin/kind:mv ./kind /usr/local/bin/kind

        查看kind的版本:kind --version

出现版本安装完成!

4.5、离线环境创建K8S集群

离线环境中想要使用 Kind 预构建的镜像创建集群时,你可以在任意可联网的机器上或目标机器上有网络的情况下,提前下载该镜像,并拷贝至需要创建集群的目标机器上,这边已经下载好

4.5.1、导入预构建镜像

执行:docker load -i kindest-node.tar,可以看到大小为1.12GB的镜像,(TAG和名字没有原因暂时未知,不影响使用,可以自己打tag

4.5.2、使用镜像创建单节点k8s

创建单节点集群: kind create cluster --image {镜像id},然后执行kubectl get node可以看到大概45s就可以创建一个单节点的k8s。默认的集群名称为 kind,在创建的时候我们可以使用参数 --name 指定创建的集群名称,可以创建多个群集。

备注:# kind create cluster,kind创建集群的时候从,他会自动去配置kubeconfig文件,所以可直接使用kubectl管理kind创建的集群。

查看pod:kubectl get pod -n kube-system可以查看pod,kubectl get svc/deploy/configmap等。

默认方式启动的节点类型是 control-plane 类型,包含了所有的组件。包括2 * coredns、etcd、api-server、controller-manager、kube-proxy、sheduler、cni

备注:# kindnet是kind安装k8s集群是已经默认配置好的cni插件;

4.5.3、使用镜像来创建集群

我们还可以通过一个文件来配置要创建的 K8s 集群,比如定义一个如下所示的 config.yaml 文件:

# config.yaml

kind: Cluster

apiVersion: kind.x-k8s.io/v1alpha4

name: demo

nodes:

 - role: control-plane

 - role: worker

 - role: worker

该配置文件表示我们一共要创建 3 个节点,一个控制节点,两个工作节点,在创建集群的时候只需要通过 --config 参数指定该文件即可。

创建后的集群名称为 demo ,一共包括 3 个节点

我们docker ps -a看一下,模拟多节点集群,其实只是在一个主机上的多个容器

4.6、其他常用的kind命令

kind删除集群:kind delete clusters kind

查看已创的k8s集群:kind get clusters

重点:Kind 集群中的 Docker 镜像可以从互联网直接拉取,有时候可能比较缓慢,我们可以将本机镜像导入到 Kind 集群中去,例子如下:

kind load docker-image flink-wc:1.13.6 --name kind

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_lishengming

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值