Setup Kubernetes Cluster with Kubeadm and Vagrant
Introduction
使用 kubeadm + vagrant 自动化部署 k8s 集群,基于 Centos7 操作系统。该工程 fork 自 kubeadm-vagrant, 对已知问题进行了修复:节点设置正确的 IP 地址「set-k8s-node-ip.sh」。否则使用过程中会出现问题,具体问题见这里:「kubeadm + vagrant 部署多节点 k8s 的一个坑」。其他一些调整:节点初始化脚本更改、Vagrantfile 添加 Shell 脚本配置器,运行初始化脚本。
默认:1 个 master 节点,1 个 node 节点,可以根据需要修改 Vagrantfile 文件。
With reference to steps listed at Using kubeadm to Create a Cluster for setting up the Kubernetes cluster with kubeadm. I have been working on an automation to setup the cluster. The result of it is kubeadm-vagrant, a github project with simple steps to setup your kubernetes cluster with more control on vagrant based virtual machines.
Vagrant Box
- Centos7
Installation
- Clone the kubeadm-vagrant repo
https://github.com/qhh0205/kubeadm-vagrant
- Configure the cluster parameters in Vagrantfile. Refer below for details of configuration options.
vi Vagrantfile
- Spin up the cluster
vagrant up
- This will spin up new Kubernetes cluster. You can check the status of cluster with following command,
sudo su
kubectl get pods --all-namespaces
Cluster Configuration Options
You need to generate a KUBETOKEN of your choice to be used while creating the cluster. You will need to install kubeadm package on your host to create the token with following command
# kubeadm token generate
148a37.736fd53655b767b7
BOX_IMAGEis currently default with "coolsvap/centos-k8s" box which is custom box created which can be used for setting up the cluster with basic dependencies for kubernetes node.- Set
SETUP_MASTERto true if you want to setup the node. This is true by default for spawning a new cluster. You can skip it for adding new minions. - Set
SETUP_NODESto true/false depending on whether you are setting up minions in the cluster. - Specify
NODE_COUNTas the count of minions in the cluster - Specify the
MASTER_IPas static IP which can be referenced for other cluster configurations - Specify
NODE_IP_NWas the network IP which can be used for assigning dynamic IPs for cluster nodes from the same network as Master - Specify custom
POD_NW_CIDRof your choice