Anisble中的变量及加密

1.变量的基本设定及使用方式

1. 变量命名
只能包含数字 下划线 字母
只能用下划线或字母开头
2. 变量级别
全局 :
从命令行或配置文件中设定的
paly :
play 和相关结构中设定的
主机 :
由清单 事实收集或注册的任务

(1)直接定义变量

vim msgtest.yaml

         - name: test playbook
          hosts: all
          tasks:
            - name: test play
              debug:
                msg: "{{msg}}"

 ansible-playbook msgtest.yaml -e msg="hello_westos"

Anisble中的变量及加密_第1张图片

(2)全局变量

vim msgtest1.yaml

         - name: test playbook
          hosts: all

          vars:

            msg:hello
          tasks:
            - name: test play
              debug:
                msg: "{{msg}}"

ansible-playbook msgtest1.yaml

Anisble中的变量及加密_第2张图片

(3)在文件中指定变量

vim var.yaml

 msg: hello_hello

vim msgtest2.yaml

        - name: test playbook
          hosts: all
          vars_files: var.yaml
          tasks:
            - name: test play
              debug:
                msg: "{{msg}}"

ansible-playbook msgtest2.yaml

Anisble中的变量及加密_第3张图片

 (4)在清单中指定

vim inventory

        [westos]
        192.168.168.89
        192.168.168.90

        [westos:vars]
        msg=helllo

ansible-playbook msgtest.yaml

Anisble中的变量及加密_第4张图片

(5)用目录设定变量

group_vars 清单变量,目录中的文件名称与主机清单名称一致
host_vars  主机变量目录中的文件名称与主机名称一致
·······group_vars ## 清单变量 , 目录中的文件名称与主机清单名称一致

vim inventory

        [westos]
        192.168.168.89
        192.168.168.90

        [westos1]
        192.168.168.89

        [westos2]
        192.168.168.90

        [westos:vars]
        msg=helllo

mkdir group_vars
vim group_vars/westos1.yaml

        msg: westos111
vim group_vars/westos2.yaml

        msg: westos111

cp msgtest.yaml msg_westos1.yaml
vim msg_westos1.yaml

         - name: test playbook
          hosts: westos1
          vars_files: var.yaml
          tasks:
            - name: test play
              debug:
                msg: "{{msg}}"

Anisble中的变量及加密_第5张图片

同理可以编辑westos2:

cp msgtest.yaml msg_westos2.yaml
vim msg_westos2.yaml

         - name: test playbook
          hosts: westos2
          vars_files: var.yaml
          tasks:
            - name: test play
              debug:
                msg: "{{msg}}"

Anisble中的变量及加密_第6张图片 ·······host_vars ##主机变量目录中的文件名称与主机名称一致

mkdir host_vars
vim host_vars/192.168.168.89.yaml
        msg: 192.168.168.89
vim host_vars/192.168.168.90.yaml
        msg: 192.168.168.90

 ansible-playbook msgtest.yaml 

Anisble中的变量及加密_第7张图片

2.变量数组及注册变量

使用数组设定变量

vim USER.yaml

        USER:
          westoslinux:
            age: 20
            sex: boy
          westos:
            age: 17
            sex: girl

vim show_USER.yaml

        - name: test vars
          hosts: all
          vars_files: ./USER.yaml
          tasks:
            - name: show vars
              debug:
                msg: "{{USER.westoslinux.age}}"

ansible-playbook show_USER.yaml 

Anisble中的变量及加密_第8张图片

vim USER1.yaml 

        USER:
          - name: westoslinux
            uid: 666
          - name: westos
            uid: 888

 vim show_USER1.yaml

        - name: test vars
          hosts: all
          vars_files: ./USER1.yaml
          tasks:
            - name: show vars
              debug:
                msg: "{{item['name']}}"
              loop:
                "{{USER}}"

 ansible-playbook show_USER1.yaml

Anisble中的变量及加密_第9张图片

注册变量
register 把模块输出注册到指定字符串中

vim register.yaml

        - name: register
          hosts: all
          tasks:
            - name: check file
              shell: id xxx
              register: outinfo

            - name: show messages
              debug:
                msg: "{{outinfo['stdout']}}"

ansible-playbook register.yaml 

Anisble中的变量及加密_第10张图片

3.变量应用实例

建立user1和user2,uid为8888和9999,密码是user1123和user2123

[devops@ansible .ansible]$ vim create_user_list.yaml

        users:
          - name: user1
            uid: 8888
            password: user1123
          - name: user2
            uid: 9999
            password: user2123

[devops@ansible .ansible]$ vim create_user.yaml

        - name: create user1,user2
          hosts: all
          vars_files: ./create_user_list.yaml
          tasks:
            - name: create user1.user2
              user:
                name: "{{item.name}}"
                uid: "{{item.uid}}"
                password: "{{item.password|password_hash('sha512')}}"
              loop: 
                "{{users}}"

ansible-playbook create_user.yaml

Anisble中的变量及加密_第11张图片

4.ansible中的事实变量的使用方法

事实变量是 ansible 在受控主机中自动检测出的变量
事实变量中还有与主机相关的信息
当需要使用主机相关信息时不需要采集赋值 直接调用即可
因为变量信息为系统信息所以不能随意设定仅为采集信息 故被成为事实变量
采集事实变量:
vim ansible_facts.yaml
        - name: test playbook
          hosts: all
          tasks:
            - name: test message
              debug:
                msg: "{{ansible_facts['all_ipv4_addresses']}}"
ansible-playbook ansible_facts.yaml
Anisble中的变量及加密_第12张图片
关闭采集事实变量:
vim ansible_facts_no.yaml
        - name: test playbook
          hosts: all
          gather_facts: no
          tasks:
            - name: test message
              debug:
                msg: hello hello
ansible-playbook ansible_facts_no.yaml
Anisble中的变量及加密_第13张图片
采集IPV4信息
                msg: "{{ansible_facts['ens160']['ipv4']}}"

采集IP 

                msg: "{{ansible_facts['ens160']['ipv4']['address']}}"
采集主机名称
                msg: "{{ansible_facts['qdn']}}"
采集架构
                msg: "{{ansible_facts['architecture']}}"

5.ansible中的魔法变量

hostvars :                                 ##ansible软件的内部信息

ansible localhost -m debug -a "var=hostvars"

Anisble中的变量及加密_第14张图片

列出指定的具体内容:

ansible localhost -m debug -a "var=hostvars['192.168.155.89']['groups']['all']"

Anisble中的变量及加密_第15张图片

group_names :                              当前受管主机所在组
ansible all -m debug -a "var=group_names"

Anisble中的变量及加密_第16张图片

groups :                                      列出清单中所有的组和主机
ansible all -m debug -a "var=groups"

 Anisble中的变量及加密_第17张图片

inventory_hostname :                            包含清单中配置的当前授管主机的名称
ansible all -m debug -a "var=inventory_hostname"

 Anisble中的变量及加密_第18张图片

6.jinja2模板的书写及使用规则

介绍
Jinja2 Python 下一个被广泛应用的模版引擎
他的设计思想来源于 Django 的模板引擎
并扩展了其语法和一系列强大的功能
其中最显著的一个是增加了沙箱执行功能和可选的自动转义功能

vim j2_test.j2

        {# test j2 #}                                        这是注释
        hello world

vim j2_test.yaml

        - name: test j2
          hosts: all
          tasks:
            - name: create file
              template:
                src: ./j2_test.j2
                dest: /mnt/j2_test

ansible-playbook j2_test.yaml

ansible all -m shell -a 'cat /mnt/j2_test'

Anisble中的变量及加密_第19张图片

vim j2_test_for.j2

        {# test j2 for #}
        {% for user in users %}
        {{user}}
        {% endfor %}

vim j2_test_for.yaml 

         - name: test j2 for
          hosts: all
          vars:
            users:
              - westos
              - linux
              - ansible
          tasks:
            - name: create file
              template:
                src: ./j2_test_for.j2
                dest: /mnt/j2_test_for

ansible-playbook j2_test_for.yaml

Anisble中的变量及加密_第20张图片

显示行号(从1开始计数)

Anisble中的变量及加密_第21张图片

从0开始计数

Anisble中的变量及加密_第22张图片

vim j2_test_if.j2 

        {# test j2 if #}
        {% for user in users %}
        {%if user == "linux" %}
        {{loop.index0}}-{{user}}
        {%endif%}
        {%if user != "linux" %}
        {{user}}
        {%endif%}
        {% endfor %}

vim j2_test_if.yaml 

        - name: test j2 if
          hosts: all
          vars:
            users:
              - westos
              - linux
              - ansible
          tasks:
            - name: create file
              template:
                src: ./j2_test_if.j2
                dest: /mnt/j2_test_if

 ansible-playbook j2_test_if.yaml

ansible all -m shell -a 'cat /mnt/j2_test_if'

Anisble中的变量及加密_第23张图片

cat j2_test_if_age.j2 

        {# test j2 if_age #}
        {% for user in users %}
        name: {{ user.name }}
        {%if user.age is defined %}
        age:    {{user.age}}
        {%endif%}
        {%if user.age is not defined %}
        age:    none
        {%endif%}
        {% endfor %}

vim j2_test_if_age.yaml 

        - name: test j2 if_age
          hosts: all
          vars:
            users:
              - name: westos
                age: 19
              - name: linux
              - name: ansible
                age: 88
          tasks:
            - name: create file
              template:
                src: ./j2_test_if_age.j2
                dest: /mnt/j2_test_if_age

ansible-playbook j2_test_if_age.yaml

ansible all -m shell -a 'cat /mnt/j2_test_if_age'

Anisble中的变量及加密_第24张图片

7.jinja2模板实例

采集主机的ip地址和主机名字

vim hosts.j2 

{% for HOST in groups['all'] %}
{{hostvars[HOST]['ansible_facts']['ens160']['ipv4']['address']}}                   {{hostvars[HOST]['ansible_facts']['fqdn']}}
{%endfor%}

vim hosts.yaml 

- name: test hosts
  hosts: all
  tasks:
    - name: hosts
      template:
        src: ./hosts.j2
        dest: /mnt/hosts

ansible-playbook hosts.yaml

ansible all -m shell -a 'cat /mnt/hosts'

Anisble中的变量及加密_第25张图片

8.ansible中对文件加密

加密

ansible-vault encrypt test.yml

Anisble中的变量及加密_第26张图片

 查看加密文件

ansible-vault view test.yml 

编辑加密文件

ansible-vault edit test.yml 

用文件指定加密

vim passwordfile
        000000
ansible-vault edit test.yml --vault-password-file passwordfile 

 重设加密文件

 ansible-vault rekey test.yml 

 解除加密

 ansible-vault decrypt test.yml 

创建加密文件

ansible-vault create jiamifile

Anisble中的变量及加密_第27张图片

Anisble中的变量及加密_第28张图片

你可能感兴趣的:(学习)