kubernetes 从一发布开始其学习门槛就比较高,首先就是部署难,用户要想学习 kubernetes 必须要过部署这一关,社区也推出了多个部署工具帮助简化集群的部署,社区中推出的部署工具主要目标有两大类,部署测试环境与生产环境,本节主要讲述测试环境的部署,目前社区已经有多套部署方案了:
- https://github.com/bsycorp/kind
- https://github.com/ubuntu/microk8s
- https://github.com/kinvolk/kube-spawn
- https://github.com/kubernetes/minikube
- https://github.com/danderson/virtuakube
- https://github.com/kubernetes-sigs/kubeadm-dind-cluster
而本文主要讲述使用 kind(Kubernetes In Docker)部署 k8s 集群,因为 kind 使用起来实在太简单了,特别适用于在本机部署测试环境。
kind 的原理就是将 k8s 所需要的所有组件,全部部署在一个 docker 容器中,只需要一个镜像即可部署一套 k8s 环境,其底层是使用 kubeadm 进行部署,CRI 使用 Containerd,CNI 使用 weave。下面就来看看如何使用 kind 部署一套 kubernetes 环境,在使用 kind 前你需要确保目标机器已经安装了 docker 服务。
一、使用 kind 部署 k8s 集群
以下安装环境为 mac os。
安装 kind :
1 | $ wget https://github.com/kubernetes-sigs/kind/releases/download/v0.5.1/kind-darwin-amd64 |
使用 kind 部署 kubernetes 集群:
1 | // 默认的 cluster name 为 kind,可以使用 --name 指定 |
使用 kind create cluster 安装,是没有指定任何配置文件的安装方式。从安装打印出的输出来看,分为 6 步:
- 安装基础镜像 kindest/node:v1.15.4,这个镜像里面包含了所需要的二进制文件、配置文件以及 k8s 左右组件镜像的 tar 包
- 准备 node,检查环境、启动镜像等工作
- 生成 kubeadm 的配置,然后使用 kubeadm 安装,和直接使用 kubeadm 的步骤类似
- 启动服务
- 部署 CNI 插件,kind 默认使用 weave。
- 创建 StorageClass。
1 | // 查看 kubeconfig path |
kind 还有多个子命令,此处不再一一详解。
1 | // 查看集群信息, |
可以看到,kind 容器暴露的 6443 端口映射在本机的一个随机端口(55387)上。
1 | // 查看 node 的详细信息,可以看到 cni 为 containerd |
删除集群:
1 | $ kind delete cluster |
kind 也支持创建多 master 以及多 work 节点的集群,需要自定义 yaml 配置:
1 | # a cluster with 3 control-plane nodes and 3 workers |
kind 还支持自定义映射的端口号、支持使用自定义镜像仓库、支持启用 Feature Gates 等多个功能,详细的使用请参考官方文档 quick-start。
二、本地测试
既然 kind 不能用作生产环境,那怎么在本地测试时使用呢?由于 k8s 的新版已经全面启用了 TLS,不再支持非安全端口,访问 APIServer 的接口都需要认证,但是本地测试不需要那么麻烦,如下所示,为匿名用户设置访问权限即可。
1 | // 为匿名用户关联 RBAC 规则 |