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. 192.168.40.112 knode1
  3. 192.168.40.113 knode2
  4. 192.168.40.114 knode3

2.在Ansible服务器上的/etc/ansible/hosts文件中添加k8s服务器节点(参考 ansible_hosts

  1. [k8s-all]
  2. kmaster
  3. knode1
  4. knode2
  5. knode3
  6. [k8s-master]
  7. kmaster
  8. [k8s-nodes]
  9. knode1
  10. knode2
  11. knode3

三. 修改k8s集群各节点/etc/hosts(非必须)

修改所有主机/etc/hosts文件,添加IP/主机名映射,方便通过主机名ssh访问

1.创建playbook文件(参考 set_hosts_playbook.yml

  1. vim set_hosts_playbook.yml
  2. ---
  3. - hosts: k8s-all
  4. remote_user: root
  5. tasks:
  6. - name: backup /etc/hosts
  7. shell: mv /etc/hosts /etc/hosts_bak
  8. - name: copy local hosts file to remote
  9. copy: src=/etc/hosts dest=/etc/ owner=root group=root mode=0644

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. - hosts: k8s-all
  3. remote_user: root
  4. vars:
  5. docker_version: 18.09.2
  6. tasks:
  7. - name: install dependencies
  8. #shell: yum install -y yum-utils device-mapper-persistent-data lvm2
  9. yum: name={{item}} state=present
  10. with_items:
  11. - yum-utils
  12. - device-mapper-persistent-data
  13. - lvm2
  14. - name: config yum repo
  15. shell: yum-config-manager --add-repo https://mirrors.ustc.edu.cn/docker-ce/linux/centos/docker-ce.repo
  16. - name: install docker
  17. yum: name=docker-ce-{{docker_version}} state=present
  18. - name: start docker
  19. shell: systemctl enable docker && systemctl start docker

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
  2. - hosts: k8s-master
  3. remote_user: rootq
  4. vars:
  5. kube_version: 1.16.0-0
  6. k8s_version: v1.16.0
  7. k8s_master: 192.168.40.111
  8. tasks:
  9. - name: prepare env
  10. script: ./pre-setup.sh
  11. - name: install kubectl,kubeadm,kubelet
  12. yum: name={{item}} state=present
  13. with_items:
  14. - kubectl-{{kube_version}}
  15. - kubeadm-{{kube_version}}
  16. - kubelet-{{kube_version}}
  17. - name: init k8s
  18. shell: kubeadm init --image-repository registry.aliyuncs.com/google_containers --kubernetes-version {{k8s_version}} --apiserver-advertise-address {{k8s_master}} --pod-network-cidr=10.244.0.0/16 --token-ttl 0
  19. - name: config kube
  20. shell: mkdir -p $HOME/.kube && cp -i /etc/kubernetes/admin.conf $HOME/.kube/config && chown $(id -u):$(id -g) $HOME/.kube/config
  21. - name: copy flannel yaml file
  22. copy: src=./kube-flannel.yml dest=/tmp/ owner=root group=root mode=0644
  23. - name: install flannel
  24. shell: kubectl apply -f /tmp/kube-flannel.yml
  25. - name: get join command
  26. shell: kubeadm token create --print-join-command
  27. register: join_command
  28. - name: show join command
  29. debug: var=join_command verbosity=0

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
  2. - hosts: k8s-nodes
  3. remote_user: root
  4. vars:
  5. kube_version: 1.16.0-0
  6. tasks:
  7. - name: prepare env
  8. script: ./pre-setup.sh
  9. - name: install kubeadm,kubelet
  10. yum: name={{item}} state=present
  11. with_items:
  12. - kubeadm-{{kube_version}}
  13. - kubelet-{{kube_version}}
  14. - name: start kubelt
  15. shell: systemctl enable kubelet && systemctl start kubelet
  16. - name: join cluster
  17. shell: kubeadm join 192.168.40.111:6443 --token zgx3ov.zlq3jh12atw1zh8r --discovery-token-ca-cert-hash sha256:60b7c62687974ec5803e0b69cfc7ccc2c4a8236e59c8e8b8a67f726358863fa7

3.执行ansible-playbook

  1. ansible-playbook deploy_nodes_playbook.yml

4.稍等片刻,即可在master节点上通过kubectl get nodes看到加入到集群中的节点,并且status为Ready状态,如下

  1. [root@kmaster ~]# kubectl get nodes
  2. NAME STATUS ROLES AGE VERSION
  3. kmaster Ready master 37m v1.16.0
  4. knode1 Ready <none> 7m1s v1.16.0
  5. knode2 Ready <none> 7m1s v1.16.0
  6. knode3 Ready <none> 4m12s v1.16.0

至此,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
  2. :s/quay.io/quay-mirror.qiniu.com/g
  3. vim nginx-ingress.yaml
  4. spec:
  5. hostNetwork: true
  6. nodeSelector:
  7. nginx-ingress: "true"

3.部署Ingress

首先在knode1节点上打标签nginx-ingress=true,控制Ingress部署到knode1上,保持IP固定。

  1. [root@kmaster k8s-deploy]# kubectl label node knode1 nginx-ingress=true
  2. node/knode1 labeled

然后完成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
  2. NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
  3. ingress-nginx-admission-create-drpg5 0/1 Completed 0 79m 10.244.2.2 knode1 <none> <none>
  4. ingress-nginx-admission-patch-db2rt 0/1 Completed 1 79m 10.244.3.2 knode3 <none> <none>
  5. ingress-nginx-controller-575cffb49c-4xm55 1/1 Running 0 79m 192.168.40.112 knode1 <none> <none>

八. 安装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
  2. apiVersion: v1
  3. metadata:
  4. labels:
  5. k8s-app: kubernetes-dashboard
  6. name: kubernetes-dashboard
  7. namespace: kubernetes-dashboard
  8. spec:
  9. type: NodePort
  10. ports:
  11. - port: 443
  12. targetPort: 8443
  13. nodePort: 30443
  14. selector:
  15. k8s-app: kubernetes-dashboard

3.部署Dashboard,并创建绑定cluster-admin角色的ServiceAccount —— admin-user (参考 auth.yaml)

  1. kubectl apply -f kubernetes-dashboard.yaml
  2. kubectl apply -f kubernetes-dashboard-auth.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. #生成私钥
  3. [root@kmaster pki]# openssl genrsa -out dashboard.key 2048
  4. #生成证书
  5. [root@kmaster pki]# openssl req -new -key dashboard.key -out dashboard.csr -subj "/O=JBST/CN=kubernetes-dashboard"
  6. #使用集群的CA来签署证书
  7. [root@kmaster pki]# openssl x509 -req -in dashboard.csr -CA ca.crt -CAkey ca.key -CAcreateserial -out dashboard.crt -days 3650
  8. #查看自创证书
  9. [root@kmaster pki]# openssl x509 -in dashboard.crt -noout -text

2.注释 kubernetes-dashboard.yaml 中默认的Secret,

  1. #---
  2. #
  3. #apiVersion: v1
  4. #kind: Secret
  5. #metadata:
  6. # labels:
  7. # k8s-app: kubernetes-dashboard
  8. # name: kubernetes-dashboard-certs
  9. # namespace: kubernetes-dashboard
  10. #type: Opaque

3.重新部署Dashboard,并通过自定义证书创建新的Secret

  1. [root@kmaster k8s-deploy]# kubectl delete -f kubernetes-dashboard.yaml
  2. [root@kmaster k8s-deploy]# kubectl apply -f kubernetes-dashboard.yaml
  3. [root@kmaster k8s-deploy]# kubectl create secret generic kubernetes-dashboard-certs --from-file=dashboard.crt=/etc/kubernetes/pki/dashboard.crt --from-file=dashboard.key=/etc/kubernetes/pki/dashboard.key -n kubernetes-dashboard

十. 在本地(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
  2. NAME STATUS ROLES AGE VERSION
  3. kmaster Ready master 4d19h v1.16.0
  4. knode1 Ready <none> 4d19h v1.16.0
  5. knode2 Ready <none> 4d19h v1.16.0
  6. knode3 Ready <none> 4d19h v1.16.0

本文所涉及的所有配置文件可在这里找到 github


相关阅读:


欢迎关注作者公众号:空山新雨的技术空间

Kubernetes笔记(一):十分钟部署一套K8s环境的更多相关文章

  1. 使用kubeadm快速部署一套K8S集群

    一.Kubernetes概述 1.1 Kubernetes是什么 Kubernetes是Google在2014年开源的一个容器集群管理系统,Kubernetes简称K8S. K8S用于容器化应用程序的 ...

  2. 【Python笔记】十分钟搞定pandas

    本文是对pandas官方网站上<10 Minutes to pandas>的一个简单的翻译,原文在这里.这篇文章是对pandas的一个简单的介绍,详细的介绍请参考:Cookbook .习惯 ...

  3. 使用ubuntu charmed kubernetes 部署一套生产环境的集群

    官方文档: https://ubuntu.com/kubernetes/docs 搭建一个基本的集群 集群ip规划 hostname ip ubuntu-1 10.0.0.10 juju-contro ...

  4. Hadoop 学习笔记 (十) hadoop2.2.0 生产环境部署 HDFS HA Federation 含Yarn部署

    其他的配置跟HDFS-HA部署方式完全一样.但JournalNOde的配置不一样>hadoop-cluster1中的nn1和nn2和hadoop-cluster2中的nn3和nn4可以公用同样的 ...

  5. 十分钟部署Anemometer作为Mysql慢查询可视化系统

    前言 采用Anemometer将Mysql慢查询日志可视化,可以更便捷的查询慢查询日志,并根据时间戳进行历史查询.如下是单机版Anemometer部署的演示,实际应用中,为安全起见,建议把anemom ...

  6. 五分钟部署一套完整的Zabbix

    Zabbix-安装与使用 安装NTP yum install -y ntp 配置ntp.conf cd /etc/ vim ntp.conf # 打开之后讲一下内容添加 server cn.ntp.o ...

  7. 十分钟上手-搭建vue开发环境(新手教程)

    想写一些关于vue的文章已经很久了,因为这个框架已经火了很久,在公司里用的框架都比较老旧,但怎么也得跟上前端发展变化的潮流,这不,开始使用vue开发项目了,一遍开发一边踩坑中,今天要记录的是五分钟搭建 ...

  8. Kubernetes笔记(二):了解k8s的基本组件与概念

    前文 Kubernetes笔记(一):十分钟部署一套K8s环境 介绍了如何快速搭建一个k8s系统.为了继续使用k8s来部署我们的应用,需要先对k8s中的一些基本组件与概念有个了解. Kubernete ...

  9. Kubernetes笔记(四):详解Namespace与资源限制ResourceQuota,LimitRange

    前面我们对K8s的基本组件与概念有了个大致的印象,并且基于K8s实现了一个初步的CI/CD流程,但对里面涉及的各个对象(如Namespace, Pod, Deployment, Service, In ...

随机推荐

  1. macbook中出现2003 - Can't connect to MySQL server on '127.0.0.1' (61 "Connection refused") 如何解决

    第一步 关闭mysql服务: 苹果->系统偏好设置->最下边点mysql 在弹出页面中 关闭mysql服务(点击stop mysql server) 如果这种方法没有成功: 可以使用命令行 ...

  2. 字符串中的count()方法

    描述 Python count() 方法用于统计字符串里某个字符出现的次数.可选参数为在字符串搜索的开始与结束位置. 语法 count()方法语法: str.count(sub, start= 0,e ...

  3. 探秘 RocketMQ 消息持久化机制

    我们知道 RocketMQ 是一款高性能.高可靠的分布式消息中间件,高性能和高可靠是很难兼得的.因为要保证高可靠,那么数据就必须持久化到磁盘上,将数据持久化到磁盘,那么可能就不能保证高性能了. Roc ...

  4. iOS开发 - 开发版+企业版无线发布一键打包

    背景:项目进入快速迭代期,需要快速地交付出AdHoc版本和企业无线发布版本.每次打包都要来回切换bundle identifier和code signing,浪费很多时间. 示例项目名称名称为Test ...

  5. python:列表切片知识的总结

    列表的切片操作时对其中的单个或者多个索引对应元素的操作,具有如下特点: ①.切片区间是左闭右开区间 ②.切片的下标可以表示负数,-1表示倒数第一个数,-2表示倒数第二个数 ③.默认步长是1,可增加第三 ...

  6. 浅谈Python导入外部文件

    import 和 from ... import * 有什么区别? 例如我写了个模块hello.py def print_func(args): print("Hello " + ...

  7. var、let和const的区别详解

      let 和 const 是 ECMAScript6 新推出的特性,其中 let 是能够替代 var 的"标准",所以我们探讨 var.let 和 const 的区别,首先应该知 ...

  8. Tkinter布局管理器

    Layout management in Tkinter 原英文教程地址:zetcode.com In this part of the Tkinter tutorial, we introduce ...

  9. sqlalchemy + alembic数据迁移

    需要安装的包工具 pip install pymysql pip install sqlalchemy pip install alembic   创建表 新建models.py from sqlal ...

  10. Java第七天,类的继承

    面向对象编程的三大特征: 封装.继承.多态 今天我们学习继承! 继承是多态的前提,如果没有继承就没有多态. 继承主要解决的问题就是共性抽取(将许多类共有的特性便作父类,这样可以较大程度的优化代码). ...