5.5_Ansible中的任务执行控制

##1.循环##

#循环迭代任务# 

(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

 (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

 测试:

安装并开启vsftpd、apache、dns,并在火墙中允许这些服务访问。

##2.条件##

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

测试题:
建立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 

##3.触发器##

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:
          "<VirtualHost *:{{web1.port}}>\n\tServerName {{web1.name}}\n\tDocumentRoot 
{{web1.document}}\n\tCustomLog logs/{{web1.name}}.log combined\n</VirtualHost>\n\n<VirtualHost *:
 {{web2.port}}>\n\tServerName {{web2.name}}\n\tDocumentRoot {{web2.document}}\n\tCustomLog logs/
 {{web2.name}}.log combined\n</VirtualHost>"
      notify:
        restart apache
 
  handlers:
    - name: restart apache
      service:
        name: httpd
        state: restarted

 #4.处理失败任务#

(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

(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

 (3)changed_when#

#作用:
#控制任务报告它已进行更改

#实例
---
- 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

(4)failed_when#

 #当符合条件时强制任务失败 

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

 (5)block

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

 

#测试练习#
挂载/dev/cdrom到/mnt/isodir里

如果/mnt/isodir不存在   ----->   /mnt/isodir is not exist    ----->    create /mnt/isodir

如果/mnt/isodir存在       ----->  直接挂载

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 调用 Ansible Playbook 可以通过调用命令行的方式实现,例如使用 ProcessBuilder 类来执行命令行。下面是一个简单的示例代码: ```java public static void runAnsiblePlaybook(String playbookPath, String inventoryPath) throws IOException, InterruptedException { ProcessBuilder pb = new ProcessBuilder("ansible-playbook", "-i", inventoryPath, playbookPath); pb.redirectErrorStream(true); Process process = pb.start(); BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream())); String line; while ((line = reader.readLine()) != null) { System.out.println(line); } process.waitFor(); } ``` 在这个示例,我们使用 ProcessBuilder 类来创建一个命令行进程。我们将 Ansible Playbook 命令 `ansible-playbook` 作为参数传递给 ProcessBuilder 构造函数,并使用 `-i` 选项指定主机清单文件的路径,以及使用第二个参数 `playbookPath` 指定要执行的 Playbook 文件的路径。我们还将 `redirectErrorStream` 设置为 true,以便将标准输出和标准错误流合并到一个流。 接下来,我们使用 `start()` 方法启动进程,并使用 `getInputStream()` 方法获取进程的标准输出流。我们使用 `BufferedReader` 逐行读取输出,并将其打印到控制台上。 最后,我们使用 `waitFor()` 方法等待进程完成执行。 需要注意的是,在实际应用,我们可能需要为 Ansible Playbook 设置其他参数,例如 `--extra-vars` 或 `--tags` 等。我们可以将这些参数作为命令行参数传递给 ProcessBuilder。同时,我们还需要处理进程的错误输出流,以便及时发现和处理错误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值