总结Anisble中的任务执行控制&并练习

文章目录

  • 一、循环
    • 1.简单循环
    • 2.循环散列或字典列表
  • 二、条件
  • 三、触发器
  • 四、处理失败任务
    • 1.ignore_errors
    • 2.force_handlers
    • 3.changed_when
    • 4.failed_when
    • 5.block
  • 五、 练习
    • 建立大小为1500M名为/dev/sdb1的设备
    • 利用ansible循环安装且开启vsftpd,apache,dns,并在火墙中设定
    • 建立用户
    • 挂载,检测是否存在
  • 六、重要:ansible-doc用法


一、循环

循环迭代任务

1.简单循环

loop:         ##赋值列表
 - value1
 - value2
 - ...
{{item}}     ##迭代变量名称

#实例#
---
- name: create file
  hosts: 172.25.0.254
  tasks:
    - name: file module
      file:
        name: /mnt/{{item}}
        state: present
      loop:
        - westos_file1
        - westos_file2

总结Anisble中的任务执行控制&并练习_第1张图片

总结Anisble中的任务执行控制&并练习_第2张图片

2.循环散列或字典列表

---
- name: create file
  hosts: 172.25.0.254
  tasks:
    - name: file module
      service:
        name: "{{ item.name}}"
        state: "{{ item.state }}"
      loop:
        - name: httpd
          state: started
        - name: vsftpd
          state: stopped

总结Anisble中的任务执行控制&并练习_第3张图片
总结Anisble中的任务执行控制&并练习_第4张图片

二、条件

when:
  - 条件1
  - 条件2
#条件判断#
=                     value == "字符串",value == 数字
<                     value < 数字
>                     value > 数字
<=                    value <= 数字
>=                    value >= 数字
!=                    value != 数字
is defined value      value is defined         变量存在
is not defined        value is not defined     变量不存在
in                    value is in value        变量为 
not in                value is not in value    变量不为
bool变量 为true        value                   value的值为true
bool变量 false         not value               value的值为false
                       value in value2         value的值在value2列表中
#多条条件组合#
when:
 条件1 and 条件2
  - 条件1
  - 条件2
when:
 条件1 or 条件2
when: >
 条件1
 or
 条件2

总结Anisble中的任务执行控制&并练习_第5张图片
总结Anisble中的任务执行控制&并练习_第6张图片
2.
总结Anisble中的任务执行控制&并练习_第7张图片
总结Anisble中的任务执行控制&并练习_第8张图片
3.多个条件
总结Anisble中的任务执行控制&并练习_第9张图片
总结Anisble中的任务执行控制&并练习_第10张图片
4.true和false
总结Anisble中的任务执行控制&并练习_第11张图片

总结Anisble中的任务执行控制&并练习_第12张图片

三、触发器

notify:      触发器当遇到更改是触发handlers
handlers:   触发器触发后执行的动作
#实例#
---
- name: create virtualhost for web server
  hosts: 172.25.0.254
  vars_files:
    ./vhost_list.yml
  tasks:
    - name: create document
      file:
        path: "{{web2.document}}"
        state: directory
    - name: create vhost.conf
      copy:
        dest: /etc/httpd/conf.d/vhost.conf
        content:
          "\n\tServerName {{web1.name}}\n\tDocumentRoot 
{{web1.document}}\n\tCustomLog logs/{{web1.name}}.log combined\n\n\n\n\tServerName {{web2.name}}\n\tDocumentRoot {{web2.document}}\n\tCustomLog logs/
{{web2.name}}.log combined\n"
      notify:
        restart apache
  handlers:
    - name: restart apache
      service:
        name: httpd
        state: restarted

总结Anisble中的任务执行控制&并练习_第13张图片

四、处理失败任务

1.ignore_errors

#作用:
当play遇到任务失败时会终止
ignore_errors: yes 将会忽略任务失败使下面的任务继续运行

#实例#
- name: test
  dnf:
    name: westos
    state: latest
  ignore_errors: yes
 
- name: create file
  file:
    path: /mnt/westos
    state: touch

总结Anisble中的任务执行控制&并练习_第14张图片
总结Anisble中的任务执行控制&并练习_第15张图片

2.force_handlers

#作用:
#当任务失败后play被终止也会调用触发器进程

#example
---
- name: apache change port
  hosts: 172.25.0.254
  force_handlers: yes
  vars:
    http_port: 80
  tasks:
    - name: configure apache conf file
      lineinfile:
        path: /etc/httpd/conf/httpd.conf
        regexp: "^Listen"
        line: "Listen {{ http_port }}"
      notify: restart apache
      
    - name: install error
      dnf:
        name: westos
        state: latest
  handlers:
    - name: restart apache
      service:
        name: httpd
        state: restarted
        enabled: yes

更改24、25主机的ftp匿名用户访问
在这里插入图片描述
总结Anisble中的任务执行控制&并练习_第16张图片
总结Anisble中的任务执行控制&并练习_第17张图片
总结Anisble中的任务执行控制&并练习_第18张图片

3.changed_when

#作用:
#控制任务在何时报告它已进行更改;强制更改:true,强制不更改:false

---
- name: apache change port
  hosts: 172.25.0.254
  force_handlers: yes
  vars:
    http_port: 8080
  tasks:
    - name: configure apache conf file
      lineinfile:
        path: /etc/httpd/conf/httpd.conf
        regexp: "^Listen"
        line: "Listen {{ http_port }}"
      changed_when: true
      notify: restart apache
  handlers:
    - name: restart apache
      service:
        name: httpd
        state: restarted
        enabled: yes

总结Anisble中的任务执行控制&并练习_第19张图片
总结Anisble中的任务执行控制&并练习_第20张图片

4.failed_when

#当符合条件时强制任务失败
#强制某个play为失败状态

---
- name: test
  hosts: 172.25.0.254
  tasks:
    - name: shell
      shell: echo hello
      register: westos
      failed_when: "'hello' in westos.stdout"

总结Anisble中的任务执行控制&并练习_第21张图片
总结Anisble中的任务执行控制&并练习_第22张图片
总结Anisble中的任务执行控制&并练习_第23张图片

5.block

block:       ##定义要运行的任务
rescue:      ##定义当block句子中出现失败任务后运行的任务
             ##block运行成功,则rescue不运行
always:     ##定义最终独立运行的任务

1
总结Anisble中的任务执行控制&并练习_第24张图片
总结Anisble中的任务执行控制&并练习_第25张图片
2总结Anisble中的任务执行控制&并练习_第26张图片
总结Anisble中的任务执行控制&并练习_第27张图片

五、 练习

测试题:
建立playbook ~/ansibles/lvm.yml要求如下:
*建立大小为1500M名为exam_lvm的lvm 在westos组中
*如果westos不存在请输出:
 vg westos is not exist
*如果westos大小不足1500M请输出:
 vg westos is less then 1500M
并建立800M大小的lvm

建立大小为1500M名为/dev/sdb1的设备

#测试练习#
建立playbook ~/westos.yml要求如下:
建立大小为1500M名为/dev/sdb1的设备
如果/dev/sdb不存在请输入:
 /dev/vdb is not exist
如果/dev/sdb大小不足2G请输出:
 /dev/vdb is less then 2G
并建立800M大小的/dev/sdb1
此设备挂载到/westos上

实验前提:在24主机建立1G硬盘,25主机无硬盘
总结Anisble中的任务执行控制&并练习_第28张图片
总结Anisble中的任务执行控制&并练习_第29张图片

总结Anisble中的任务执行控制&并练习_第30张图片
总结Anisble中的任务执行控制&并练习_第31张图片

利用ansible循环安装且开启vsftpd,apache,dns,并在火墙中设定

总结Anisble中的任务执行控制&并练习_第32张图片
总结Anisble中的任务执行控制&并练习_第33张图片
实验中遇到的问题:主机网络仓库未镜像!!!
总结Anisble中的任务执行控制&并练习_第34张图片

建立用户

建立用户user1、user2;密码均为:westos
在建立用户时需要检测用户是否存在,如果用户存在保持原密码不变!!
总结Anisble中的任务执行控制&并练习_第35张图片

总结Anisble中的任务执行控制&并练习_第36张图片

挂载,检测是否存在

挂载/dev/cdrom 至/mnt/isodir
检测/mnt/isodir是否存在
不存在:输出:/mnt/isodir is not exist ,并且建立:/mnt/isodir
存在:直接挂载
总结Anisble中的任务执行控制&并练习_第37张图片

总结Anisble中的任务执行控制&并练习_第38张图片
总结Anisble中的任务执行控制&并练习_第39张图片

六、重要:ansible-doc用法

总结Anisble中的任务执行控制&并练习_第40张图片

你可能感兴趣的:(ansible,c#,开发语言)