前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用 kind 部署单机版 kubernetes 集群

使用 kind 部署单机版 kubernetes 集群

作者头像
田飞雨
发布2019-12-20 17:16:57
2.5K0
发布2019-12-20 17:16:57
举报
文章被收录于专栏:田飞雨的专栏田飞雨的专栏

kubernetes 从一发布开始其学习门槛就比较高,首先就是部署难,用户要想学习 kubernetes 必须要过部署这一关,社区也推出了多个部署工具帮助简化集群的部署,社区中推出的部署工具主要目标有两大类,部署测试环境与生产环境,本节主要讲述测试环境的部署,目前社区已经有多套部署方案了:

而本文主要讲述使用 kind(Kubernetes In Docker)部署 k8s 集群,因为 kind 使用起来实在太简单了,特别适用于在本机部署测试环境。

kind 的原理就是将 k8s 所需要的所有组件,全部部署在一个 docker 容器中,只需要一个镜像即可部署一套 k8s 环境,其底层是使用 kubeadm 进行部署,CRI 使用 Containerd,CNI 使用 weave。下面就来看看如何使用 kind 部署一套 kubernetes 环境,在使用 kind 前你需要确保目标机器已经安装了 docker 服务。

一、使用 kind 部署 k8s 集群

以下安装环境为 mac os。

安装 kind :

代码语言:javascript
复制
$ wget https://github.com/kubernetes-sigs/kind/releases/download/v0.5.1/kind-darwin-amd64
$ chmod +x kind-darwin-amd64
$ mv kind-darwin-amd64 /usr/local/bin/kind

使用 kind 部署 kubernetes 集群:

代码语言:javascript
复制
// 默认的 cluster name 为 kind,可以使用 --name 指定
$ kind create cluster
Creating cluster "kind" ...
 ✓ Ensuring node image (kindest/node:v1.15.3) ?
 ✓ Preparing nodes ?
 ✓ Creating kubeadm config ?
 ✓ Starting control-plane ?️
 ✓ Installing CNI ?
 ✓ Installing StorageClass ?
Cluster creation complete. You can now use the cluster with:

使用 kind create cluster 安装,是没有指定任何配置文件的安装方式。从安装打印出的输出来看,分为 6 步:

  1. 安装基础镜像 kindest/node:v1.15.4,这个镜像里面包含了所需要的二进制文件、配置文件以及 k8s 左右组件镜像的 tar 包
  2. 准备 node,检查环境、启动镜像等工作
  3. 生成 kubeadm 的配置,然后使用 kubeadm 安装,和直接使用 kubeadm 的步骤类似
  4. 启动服务
  5. 部署 CNI 插件,kind 默认使用 weave。
  6. 创建 StorageClass。
代码语言:javascript
复制
// 查看 kubeconfig path
$ kind get kubeconfig-path
/Users/feiyu/.kube/kind-config-kind

$ export KUBECONFIG="$(kind get kubeconfig-path --name="kind")"

kind 还有多个子命令,此处不再一一详解。

代码语言:javascript
复制
// 查看集群信息,
$ kubectl cluster-info
Kubernetes master is running at https://127.0.0.1:55387
KubeDNS is running at https://127.0.0.1:55387/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy

To further debug and diagnose cluster problems, use 'kubectl cluster-info dump'.


// 查看本地的 kind 容器
$ docker ps
CONTAINER ID        IMAGE                  COMMAND                  CREATED             STATUS              PORTS                                  NAMES
e26545538cc7        kindest/node:v1.15.3   "/usr/local/bin/entr…"   15 minutes ago      Up 15 minutes       55387/tcp, 127.0.0.1:55387->6443/tcp   kind-control-plane

可以看到,kind 容器暴露的 6443 端口映射在本机的一个随机端口(55387)上。

代码语言:javascript
复制
// 查看 node 的详细信息,可以看到 cni 为 containerd
$ kubectl describe node kind-control-plane
...
 Container Runtime Version:  containerd://1.2.6-0ubuntu1
 Kubelet Version:            v1.15.3
 Kube-Proxy Version:         v1.15.3
PodCIDR:                     10.244.0.0/24
ExternalID:                  kind-control-plane
...


# 进入 kind 容器查看 k8s 的配置,和单独使用 kubeadm 时一致
$ docker exec -it e26545538cc  bash
root@kind-control-plane:~# ls /etc/kubernetes/
admin.conf  controller-manager.conf  kubelet.conf  manifests  pki  scheduler.conf
root@kind-control-plane:~# ls /etc/kubernetes/manifests/
etcd.yaml  kube-apiserver.yaml  kube-controller-manager.yaml  kube-scheduler.yaml


# 查看 cni 配置
root@kind-control-plane:/etc/kubernetes# cat /var/lib/kubelet/kubeadm-flags.env
KUBELET_KUBEADM_ARGS="--container-runtime=remote --container-runtime-endpoint=/run/containerd/containerd.sock --fail-swap-on=false --node-ip=172.17.0.2"


# 查看容器的状态
root@kind-control-plane:~# crictl pods
POD ID              CREATED             STATE               NAME                                         NAMESPACE           ATTEMPT
fc8700af77ca2       About an hour ago   Ready               coredns-5c98db65d4-bjxl2                     kube-system         0
6378297d32811       About an hour ago   Ready               coredns-5c98db65d4-q2drh                     kube-system         0
124b42a35e0d1       About an hour ago   Ready               kube-proxy-99nc9                             kube-system         0
54b9511069534       About an hour ago   Ready               kindnet-xz8dp                                kube-system         0
61cb720ddece8       About an hour ago   Ready               etcd-kind-control-plane                      kube-system         0
4514b98de1a44       About an hour ago   Ready               kube-scheduler-kind-control-plane            kube-system         0
9a29dbebc8dd1       About an hour ago   Ready               kube-controller-manager-kind-control-plane   kube-system         0
ab028c5f5a3e5       About an hour ago   Ready               kube-apiserver-kind-control-plane            kube-system         0

删除集群:

代码语言:javascript
复制
$ kind delete cluster

kind 也支持创建多 master 以及多 work 节点的集群,需要自定义 yaml 配置:

代码语言:javascript
复制
# a cluster with 3 control-plane nodes and 3 workers
kind: Cluster
apiVersion: kind.sigs.k8s.io/v1alpha3
nodes:
- role: control-plane
- role: control-plane
- role: control-plane
- role: worker
- role: worker
- role: worker

// 创建集群指定 config
$ kind create cluster --config kind.yaml

kind 还支持自定义映射的端口号、支持使用自定义镜像仓库、支持启用 Feature Gates 等多个功能,详细的使用请参考官方文档 quick-start

二、本地测试

既然 kind 不能用作生产环境,那怎么在本地测试时使用呢?由于 k8s 的新版已经全面启用了 TLS,不再支持非安全端口,访问 APIServer 的接口都需要认证,但是本地测试不需要那么麻烦,如下所示,为匿名用户设置访问权限即可。

代码语言:javascript
复制
// 为匿名用户关联 RBAC 规则
$ kubectl create clusterrolebinding system:anonymous --clusterrole=cluster-admin --user=system:anonymous

// 请求相关的 API
$ curl -k https://127.0.0.1:55387/api/v1/nodes
{
  "kind": "NodeList",
  "apiVersion": "v1",
  "metadata": {
    "selfLink": "/api/v1/nodes",
    "resourceVersion": "11844"
  },
  "items": [
  ...
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-09-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、使用 kind 部署 k8s 集群
  • 二、本地测试
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档