本地分布式开发环境搭建(使用Vagrant和Virtualbox)
当我们需要在本地开发时,更希望能够有一个开箱即用又可以方便定制的分布式开发环境,这样才能对Kubernetes本身和应用进行更好的测试。现在我们使用Vagrant和VirtualBox来创建一个这样的环境。
部署时需要使用的配置文件和vagrantfile
请见:https://github.com/rootsongjc/kubernetes-vagrant-centos-cluster
准备环境
需要准备以下软件和环境:
- 8G以上内存
- Vagrant 2.0+
- Virtualbox 5.0 +
- 提前下载kubernetes的安装包
集群
我们使用Vagrant和Virtualbox安装包含3个节点的kubernetes集群,其中master节点同时作为node节点。
IP | 主机名 | 组件 |
---|---|---|
172.17.8.101 | node1 | kube-apiserver、kube-controller-manager、kube-scheduler、etcd、kubelet、docker、flannel |
172.17.8.102 | node2 | kubelet、docker、flannel |
172.17.8.103 | node3 | kubelet、docker、flannel |
注意:以上的IP、主机名和组件都是固定在这些节点的,即使销毁后下次使用vagrant重建依然保持不变。
安装的组件
安装完成后的集群包含以下组件:
- flannel
- kubernetes dashboard
- etcd(单节点)
- kubectl
部署
确保安装好以上的准备环境后,执行下列命令启动kubernetes集群:
git clone https://github.com/rootsongjc/kubernetes-vagrant-centos-cluster.git
cd kubernetes-vagrant-centos-cluster
vagrant up
注意:克隆完Git仓库后,需要提前下载kubernetes的压缩包到kubenetes-vagrant-centos-cluster
目录下,包括如下两个文件:
- kubernetes-client-linux-amd64.tar.gz
- kubernetes-server-linux-amd64.tar.gz
如果是首次部署,会自动下载centos/7
的box,这需要花费一些时间,另外每个节点还需要下载安装一系列软件包,整个过程大概需要10几分钟。
访问kubernetes集群
vagrant ssh node1
sudo -i
kubectl get nodes
清理
vagrant destroy
rm -rf .vagrant