Ansible Playbook简介
Ansible Playbook是一种基于YAML语言的自动化配置管理工具,用于编写和执行复杂的IT任务,它使用模块化的方法来描述系统的配置和部署过程,可以轻松地实现对多台服务器的批量操作,在本教程中,我们将使用Ansible Playbook来部署Kubernetes集群。

环境准备
在开始部署Kubernetes集群之前,我们需要准备以下环境:
1、至少3台Linux服务器,操作系统为CentOS 7或Ubuntu 16.04。
2、每台服务器上安装Python 2.7或Python 3.5+。
3、每台服务器上安装Ansible 2.5.2或更高版本。
4、每台服务器上安装Docker 1.12或更高版本。
5、每台服务器上安装kubectl 1.8或更高版本。
部署Master节点
1、创建一个名为kubernetesmaster.yml的Ansible Playbook文件,内容如下:
name: 部署Kubernetes Master节点 hosts: kubernetesmaster become: yes tasks: name: 添加Kubernetes仓库 apt_repository: repo: "deb http://apt.kubernetes.io/ kubernetesxenial main" state: present filename: kubernetes.list name: 安装Kubernetes组件 apt: name: "{ { item }}" state: present update_cache: yes with_items: kubelet kubeadm kubectl kubernetescni etcd flanneld weavenet name: 初始化etcd集群 command: /usr/bin/kubeadm init podnetworkcidr=10.244.0.0/16 servicecidr=10.96.0.0/12 > /etc/kubernetes/kubeadminit.log 2>&1 & register: init_result until: "Initialized in init_result.stdout" retries: 30 delay: 52、在Ansible控制节点上运行以下命令,将Master节点添加到Inventory文件中:
ansibleinventory i inventory.ini add kubernetesmaster,192.168.1.100,k8smaster1 add kubernetesmaster,192.168.1.101,k8smaster2 add kubernetesmaster,192.168.1.102,k8smaster3inventory.ini是Ansible Inventory文件,192.168.1.100、192.168.1.101和192.168.1.102是Master节点的IP地址。
3、运行以下命令,执行Playbook:
ansibleplaybook i inventory.ini kubernetesmaster.yml tags "kubernetesmaster" vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv vvvvv vv v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v b e @vars/k8s_apiserver_token extravars "kubernetes_version=1.14.0" limit kubernetesmaster u root K@vars/k8s_apiserver_token是一个变量文件,包含了API Server的Token,请确保在运行此命令之前创建了该文件。extravars "kubernetes_version=1.14.0"表示我们要部署的Kubernetes版本为1.14.0。limit kubernetesmaster表示我们只对Master节点执行此Playbook。u root K表示以root用户身份运行Playbook,并提示输入密码。
部署Worker节点
1、创建一个名为kubernetesworker.yml的Ansible Playbook文件,内容如下:
name: 部署Kubernetes Worker节点 hosts: kubernetesworker[*] # *表示匹配所有Worker节点,即k8sworkerd{ 1,2}组中的节点。 become: yes tasks: name: 添加Kubernetes仓库 apt_repository: repo: "deb http://apt.kubernetes.io/ kubernetesxenial main" state: present filename: kubernetes.list name: 安装Kubernetes组件 apt: name: "{ { item }}" state: present update_cache: yes with_items: kubelet kubeadm kubectl kubernetescni etcd # etcd已经在Master节点上安装过,这里不需要再次安装,flannel和weave等网络插件也可以在这里安装。2、在Ansible控制节点上运行以下命令,将Worker节点添加到Inventory文件中:
ansibleinventory i inventory.ini add kubernetesworker,192.168.1.200,k8sworker1 add kubernetesworker,192.168.1.201,k8sworker2 add kubernetesworker,192.168.1.202,k8sworker3 remove kubernetesworker[*] # *表示匹配所有Worker节点,即k8sworkerd{ 1,2}组中的节点。 add kubernetesworker,<```原创文章,作者:未希,如若转载,请注明出处:https://www.kdun.com/ask/678396.html