Kubernetes是Goole开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理 —— 百度百科。
接触K8s也有半年多了,也基于阿里云平台搭建了包含多级服务、目前运行较为稳定的K8s集群(感兴趣的可参考 k8s云集群混搭模式,可能帮你节省50%以上的服务成本, k8s云集群混搭模式落地分享),但一直没来得及对其进行系统的学习,本系列文章还像以前Docker系列一样,以笔记的形式进行记录与分享,会包括理论与实践,感兴趣的同学可以关注,一起探索下目前较为流行的容器化及服务编排解决方案。
工欲善其事,必先利其器,本文先介绍如何在本地自行搭建一套k8s集群,并且采用我们前面介绍过的Ansible来提高效率(参考 Ansible简明教程)
本文所涉及的所有配置文件可在这里找到 github
一. 准备服务器节点
如果还没有服务器,可以参考 ubuntu18.04上搭建KVM虚拟机环境超完整过程 创建虚拟服务器。
服务器节点IP(hostname):
- 192.168.40.111 (kmaster)
- 192.168.40.112 (knode1)
- 192.168.40.113 (knode2)
- 192.168.40.114 (knode3)
操作系统版本:
cat /etc/redhat-release
: CentOS Linux release 7.6.1810 (Core)uname -a
: 3.10.0-957.el7.x86_64
二. 配置Ansible
如果还没有Ansible环境,可以参考 [Ansible简明教程]https://mp.weixin.qq.com/s/JIZE1RvN7Yop5dsOHJvStw) 搭建。
1.在Ansible服务器上的/etc/hosts文件中添加k8s服务器节点信息(参考 hosts)
1 | 192.168.40.111 kmaster |
2.在Ansible服务器上的/etc/ansible/hosts文件中添加k8s服务器节点(参考 ansible_hosts)
1 | [k8s-all] |
三. 修改k8s集群各节点/etc/hosts(非必须)
修改所有主机/etc/hosts文件,添加IP/主机名映射,方便通过主机名ssh访问
1.创建playbook文件(参考 set_hosts_playbook.yml)
1 | vim set_hosts_playbook.yml |
2.执行ansible-playbook
1 | ansible-playbook set_hosts_playbook.yml |
四. 安装Docker
在所有主机上安装Docker
1.创建playbook文件(参考 install_docker_playbook.yml)
1 | vim install_docker_playbook.yml |
2.执行ansible-playbook
1 | ansible-playbook install_docker_playbook.yml |
五. 部署k8s master
1.开始部署之前,需要做一些初始化处理:关闭防火墙、关闭selinux、禁用swap、配置k8s阿里云yum源等,所有操作放在脚本 pre-setup.sh 中,并在2中playbook中通过script模块执行
2.创建playbook文件 deploy_master_playbook.yml,只针对master节点,安装kubectl,kubeadm,kubelet,以及flannel(将kube-flannel.yml文件里镜像地址的quay.io改为quay-mirror.qiniu.com避免超时,参考 kube-flannel.yml)
1 | vim deploy_master_playbook.yml |
3.执行ansible-playbook
1 | ansible-playbook deploy_master_playbook.yml |
4.上述命令执行完成会输出节点加入k8s集群的命令,如下图。记下该命令,后面部署node时会用到
六. 部署k8s node
1.同master一样,开始部署之前,需要做一些初始化处理:关闭防火墙、关闭selinux、禁用swap、配置k8s阿里云yum源等,所有操作放在脚本 pre-setup.sh 中,并在2中playbook中通过script模块执行
2.创建playbook文件 deploy_nodes_playbook.yml,针对除master外的其它集群节点,安装kubeadm,kubelet,并将节点加入到k8s集群中,使用的是前面部署master时输出的加入集群命令
1 | vim deploy_nodes_playbook.yml |
3.执行ansible-playbook
1 | ansible-playbook deploy_nodes_playbook.yml |
4.稍等片刻,即可在master节点上通过kubectl get nodes
看到加入到集群中的节点,并且status为Ready状态,如下
1 | [root@kmaster ~]# kubectl get nodes |
至此,k8s集群基本部署完成。接下来可安装Ingress与Dashboard。
七. 安装Ingress
Ingress为集群内服务提供外网访问,包括基于Nginx与Traefik两个版本,这里使用比较熟悉的Nginx版本。安装Ingress的操作在master节点进行(因为前面在master节点安装并配置了kubectl,也可在其它安装并配置好了kubectl的节点进行)
1.下载yaml文件(此目录已包含 nginx-ingress.yaml,并修改了镜像地址,可直接进入第3步)
1 | wget -O nginx-ingress.yaml https://raw.githubusercontent.com/kubernetes/ingress-nginx/master/deploy/static/provider/baremetal/deploy.yaml |
2.将里面的quay.io修改为quay-mirror.qiniu.com,避免镜像拉取超时。同时在nginx-ingress-controller的Deployment上添加hostNetwork为true及nginx-ingress的标签,以使用宿主机网络与控制Ingress部署的节点
1 | vim nginx-ingress.yaml |
3.部署Ingress
首先在knode1节点上打标签nginx-ingress=true,控制Ingress部署到knode1上,保持IP固定。
1 | [root@kmaster k8s-deploy]# kubectl label node knode1 nginx-ingress=true |
然后完成nginx-ingress的部署
1 | kubectl apply -f nginx-ingress.yaml |
4.部署完成,稍等片刻等Pod创建完成,可通过如下命令查看ingress相关Pod情况
1 | [root@kmaster k8s-deploy]# kubectl get pods -n ingress-nginx -o wide |
八. 安装Kubernetes Dashboard
1.下载yaml文件(此目录已包含 kubernetes-dashboard.yaml 文件,可直接进入第3步)
1 | wget -O kubernetes-dashboard.yaml https://raw.githubusercontent.com/kubernetes/dashboard/v2.0.0-beta5/aio/deploy/recommended.yaml |
2.修改kubernetes-dashboard.yaml
将Service type改为NodePort,使得可通过IP访问Dashboard。注释掉默认的Secret(默认的secret权限很有限,看不到多少数据)
1 | kind: Service |
3.部署Dashboard,并创建绑定cluster-admin角色的ServiceAccount —— admin-user (参考 auth.yaml)
1 | kubectl apply -f kubernetes-dashboard.yaml |
4.访问Dashboard
访问 https://集群任意节点IP:30443,打开Dashboard登录页面,执行如下命令获取登录token
1 | kubectl -n kubernetes-dashboard describe secret $(kubectl -n kubernetes-dashboard get secret | grep admin-user | awk '{print $1}') |
使用token完成登录,如图
九. 解决证书无效问题
安装完后,默认的证书可能无效,在Chrome浏览中无法打开Dashboard,可通过重新生成证书解决。
1.创建自定义证书
1 | [root@kmaster ~]# cd /etc/kubernetes/pki/ |
2.注释 kubernetes-dashboard.yaml 中默认的Secret,
1 | #--- |
3.重新部署Dashboard,并通过自定义证书创建新的Secret
1 | [root@kmaster k8s-deploy]# kubectl delete -f kubernetes-dashboard.yaml |
十. 在本地(win10)管理k8s集群
1.下载kubectl windows版本: https://storage.googleapis.com/kubernetes-release/release/v1.16.0/bin/windows/amd64/kubectl.exe
2.将kubectl.exe文件所在目录加入系统环境变量的Path中
3.将master节点上 /etc/kubernetes/admin.conf 的内容拷贝到本地用户目录的 .kube/config 文件中,如 C:\Users\Administrator\.kube\config
4.验证
1 | C:\Users\Administrator>kubectl get nodes |
本文所涉及的所有配置文件可在这里找到 github
相关阅读: