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: 5
2、在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,k8smaster3
inventory.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
本网站发布或转载的文章及图片均来自网络,其原创性以及文中表达的观点和判断不代表本网站。如有问题,请联系客服处理。
发表回复