在Ansible中,Playbook是用于配置、部署和管理被控节点的剧本。它由一个或多个play(角色)组成,每个play可以包含多个task(台词,动作)。使用Ansible的Playbook,可以通过描述和执行一系列的操作步骤,让受控主机达到预期的状态。
写Playbook的目的主要有以下几点:
编写Ansible Playbook需要遵循一定的结构和语法规则。以下是一些编写Ansible Playbook的基本步骤和注意事项:
.yml
为扩展名的Playbook文件。例如,你可以创建一个名为deploy.yml
的文件。--- ?
- hosts: webservers ?
? become: yes ?
? tasks: ?
? ? - name: install nginx ?
? ? ? apt: name=nginx state=present
?
在这个示例中,hosts
字段指定了一个名为webservers
的主机组,become
字段用于执行需要管理员权限的任务。
4.定义task(任务):在Playbook中,每个任务都是一个要执行的指令或动作。你可以定义多个任务来达到你的目标。
- name: install nginx
apt: name=nginx state=present
在这个示例中,任务是安装Nginx软件包。
5.执行Playbook:使用Ansible命令行工具或脚本执行Playbook。例如,你可以运行以下命令来执行名为deploy.yml
的Playbook:
ansible-playbook deploy.yml
6.调试和优化:在执行Playbook后,检查输出和日志以确认任务是否成功执行。根据需要调试和优化Playbook以确保其正确性和效率。
1.查看ansible是否安装,如下图是已安装示例图,如果还没有可以参考我上一篇文章《Ansible介绍与安装》
2.管理的我的主机IP地址 vi /etc/ansible/hosts
[m1]
192.168.31.135
[all:vars]
ansible_user=root
ansible_password=123456
3.确定ansible能与受控机通信
4.创建一个ploybook目录,用于专门存放ploybook文件,编写playbook,名为waha.yml。
[root@localhost? /]# cd /etc/ansible
[root@localhost ansible]# mkdir playbook
[root@localhost ansible]# cd playbook/
[root@localhost playbook]# vim waha.yml
[root@localhost playbook]# cat waha.yml?
---
- name: 系统初始化 ? ? ? ? ##任务名称,自定义。
? hosts: 192.168.31.135? ? ? ##对哪个受控机进行操作。
? tasks: ? ? ? ? ? ? ? ? ? ? ?## 任务。
? ? - name: 关闭防火墙 ? ? ?##任务里可以有很多个小任务,比如这里就只有一个任务,关闭防火墙,名称自定义。
? ? ? service: ? ? ? ? ? ? ##关闭防火墙要用哪个模块。
? ? ? ? name: firewalld ? ? ? ? ?##service模块参数,作用对象。
? ? ? ? state: stopped ? ? ? ? ? ?##service模块参数,操作动作。
5.语法验证。验证没问题之后才能往后面操作。
?ansible-playbook --syntax-check waha.yml?
????
6.执行空运行,测试结果是否是我们想要的,但不实际在受控机上执行。
7.执行ploybook,查看结果。
8.之前192.168.31.135的防火墙状态
9.现在192.168.31.135的防火墙状态
?1.管理的主机IP地址 vi /etc/ansible/hosts
[m1]
192.168.31.135[m2]
192.168.31.140
[all:vars]
ansible_user=root
ansible_password=123456
3.确定ansible能与受控机通信
4.创建一个ploybook目录,用于专门存放ploybook文件,编写playbook,名为happy.yml。
[root@localhost? /]# cd /etc/ansible
[root@localhost ansible]# mkdir playbook
[root@localhost ansible]# cd playbook/
[root@localhost playbook]# vim happy.yml
[root@localhost playbook]# cat happy.yml?
---
- name: 系统初始化 ? ? ? ? ##任务名称,自定义。
? hosts: [192.168.31.135 192.168.31.140]? ? ? ##对哪个受控机进行操作。
? tasks: ? ? ? ? ? ? ? ? ? ? ?## 任务。
? ? - name: 关闭防火墙 ? ? ?##任务里可以有很多个小任务,比如这里就只有一个任务,关闭防火墙,名称自定义。
? ? ? service: ? ? ? ? ? ? ##关闭防火墙要用哪个模块。
? ? ? ? name: firewalld ? ? ? ? ?##service模块参数,作用对象。
? ? ? ? state: stopped ? ? ? ? ? ?##service模块参数,操作动作。
5.语法验证。验证没问题之后才能往后面操作。
?ansible-playbook --syntax-check happy.yml?
????
6.执行空运行,测试结果是否是我们想要的,但不实际在受控机上执行。
7.执行ploybook,查看结果。
8.之前192.168.31.135和192.168.31.140的防火墙状态
9.现在192.168.31.135和192.168.31.140的防火墙状态
如果在查看两台主机防火墙的主机的防火墙的状态时,如果防火墙都关闭了,恭喜你最基础的Ansible-playbook编译.yml脚本已经掌握!!