ansible playbook
一、ansible playbook简单使用
gather_facts参数指定了在以下任务部分执行前,是否先执行setup模块获取主机相关信息
- name: 判断
shell: ulimit -n
register: ulimit
failed_when: ulimit.stdout == "65535"
执行的shell结果保存在register中,当满足failed_when的结果时执行失败。
ansible会把role所包含的任务、变量、handlers、依赖等加载到playbook中,顺次执行。
相当于是把模块写入到配置文件里面
vim /etc/ansible/test.yml //写入如下内容:
---
- hosts: 127.0.0.1
remote_user: root
tasks:
- name: test_playbook
shell: touch /tmp/test.txt
PS: 第一行是固定写法,hosts指定对哪些主机进行操作,如果是多台可以用逗号分隔,也可以使用主机组,如testhost
user参数指定使用什么用户登录远程机器
tasks指定一个任务,name为对任务的描述,执行过程中会打印出来,shell是ansible模块名字,执行test.yml
ansible-playbook test.yml
二、playbook设置变量
vim /etc/ansible/create_user.yml //创建一个用户:
---
- name: create_user
hosts: 127.0.0.1
user: root
gather_facts: false
vars:
- user: "test"
tasks:
- name: create user
user: name="{{ user }}"
PS: name参数对该playbook做一个描述,可以省略;gather_facts参数指定在以下任务部分执行前,是否执行setup模块获取主机相关信息;vars参数,指定变量,这里指定一个user变量,值为test,值一定要用引号引住;
tasks里面的user为一个模块,下面的name为user模块的一个参数,增加的用户名字调用了上面user变量的值。
三、playbook循环
vim /etc/ansible/while.yml //创建文件以及修改权限:
---
- hosts: 127.0.0.1
user: root
gather_facts: false
tasks:
- name: touch files and change mode for files
file: path=/tmp/{{ item }} state=touch mode=600
with_items:
- 1.txt
- 2.txt
- 3.txt
PS: with_items为循环的对象
四、playbook中的条件判断
vim /etc/ansible/when.yml //写入如下内容:
---
- hosts: testhost
user: root
gather_facts: True
tasks:
- name: user when
shell: touch /tmp/when.txt
when: ansible_eno16777736.ipv4.address=="192.168.1.99"
PS: 只有满足when里面的条件时,才会去执行shell里面的内容;ansible 127.0.0.1 -m setup可以查看所有facter信息,即when里面条件在这里面去设置。
五、playbook中的handlers(tasks满足条件之后才执行)
vim /etc/ansible/handlers //写入如下内容:
---
- name: handlers test
hosts: 127.0.0.1
user: root
tasks:
- name: copy file
copy: src=/etc/passwd dest=/tmp/aaa.txt
notify: test handlers
handlers:
- name: test handlers
shell: echo "1111" >> /tmp/aaa.txt
PS:只有当copy模块真正执行后,才会去调用下面handlers相关操作,copy与notify的顺序没有关系;如果aaa.txt与passwd内容是一样的,就不会去执行handlers里面的shell命令。适用于配置文件发生更改后重启服务的操作。
########################################################################################################################
mkdir test/{invertory,roles} -p






浙公网安备 33010602011771号