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上啦,如果可以连外网的话可以直接执行安装命令,也可以到官网下载
![](https://img-blog.csdnimg.cn/direct/4a3f4e635a3444359924f107445ece82.png)
-
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学习网址
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、学习地址
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