item是循环变量,参考
变量名仅能由字母、数字和下划线组成且只能以字母开头。
facts是由正在通信的远程目标主机发回的信息这些信息被保存在ansible变量中。要获取指定的远程主机所支持的所有facts可使用如下命令进行
ansible hostname -m setup 这个命令可以获得被监控端主机的各种信息将这些信息得到后保存到变量中。
自定义变量
在 yaml 中可以使用vars关键字来定义变量
vars:
var_name: value
变量的引用
{{ var_name }}
特殊的变量迭代
当有需要重复性执行的任务时可以使用迭代机制。其使用格式为将需要迭代的内容定义为item变量引用并通过with_items语句来指明迭代的元素列表即可。
示例
例如在被控端添加 2 个用户
方式1一般做法
- name: add user testuser1
user: name=testuser1 state=present groups=wheel - name: add user testuser2
user: name=testuser2 state=present groups=wheel
方式2使用变量方式
- name: add several users
vars:
user1: testuser1
user2: testuser2
user: name={{ user1 }} state=present groups=wheel
user: name={{ user2 }} state=present groups=wheel
方式3使用迭代方式
- 创建两个用户
[root@linux-node1 create_user]# cat c_u.yml
- hosts: db
remote_user: root
tasks:
- name: add several users
user: name={{ item }} state=present groups=wheel
with_items:
- testuser1
- testuser2
- name: add several users
user: name={{ item.name }} state=present groups={{ item.groups }}
with_items:
- { name: 'testuser1', groups: 'wheel' }
- { name: 'testuser2', groups: 'root' }
-
执行
[root@linux-node1 create_user]# ansible-playbook c_u.yml PLAY [db] ****************************************************************************************************************************************** TASK [Gathering Facts] ***************************************************************************************************************************** ok: [192.168.182.129] TASK [add several users] *************************************************************************************************************************** changed: [192.168.182.129] => (item=testuser1) changed: [192.168.182.129] => (item=testuser2) TASK [add several users] *************************************************************************************************************************** ok: [192.168.182.129] => (item={u'name': u'testuser1', u'groups': u'wheel'}) changed: [192.168.182.129] => (item={u'name': u'testuser2', u'groups': u'root'}) PLAY RECAP ***************************************************************************************************************************************** 192.168.182.129 : ok=3 changed=2 unreachable=0 failed=0
-
检查结果
[root@linux-node1 create_user]# ansible db -m shell -a 'grep test* /etc/passwd' 192.168.182.129 | SUCCESS | rc=0 >> testuser1:x:3308:3308::/home/testuser1:/bin/bash testuser2:x:3309:3309::/home/testuser2:/bin/bash ```