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使用迭代方式

  1. 创建两个用户

    [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' }  
  2. 执行

    [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   
  3. 检查结果
    [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