Ansible:playbook

Ansible:playbook

  • 一、playbook 剧本
    • 1.1 playbooks 本身由以下各部分组成
    • 1.2 示例
      • 1.2.1 运行playbook
    • 1.3 定义、引用变量
    • 1.4 指定远程主机sudo切换用户
    • 1.5 Templates 模块
    • 1.6 tags 模块
    • 1.7 Roles 模块
      • 1.7.1 roles 的目录结构
      • 1.7.2 roles 内各目录含义解释
      • 1.7.3 在一个 playbook 中使用 roles 的步骤
      • 1.7.4 示例
    • 1.8 编写httpd模块
    • 1.9 编写mysql模块
    • 1.10 编写php模块
    • 1.11 编写roles示例

一、playbook 剧本

1.1 playbooks 本身由以下各部分组成

  • 1、Tasks:任务,即通过 task 调用 ansible 的模板将多个操作组织在一个 playbook 中运行
  • 2、Variables:变量
  • 3、Templates:模板
  • 4、Handlers:处理器,当changed状态条件满足时,(notify)触发执行的操作
  • 5、Roles:角色

1.2 示例

vim test1.yaml
---     #yaml文件以---开头,以表明这是一个yaml文件,可省略
- name: first play     #定义一个play的名称,可省略
  gather_facts: false    #设置不进行facts信息收集,这可以加快执行速度,可省略
  hosts: webservers    #指定要执行任务的被管理主机组,如多个主机组用冒号分隔
  remote_user: root    #指定被管理主机上执行任务的用户
  tasks:     #定义任务列表,任务列表中的各任务按次序逐个在hosts中指定的主机上执行
   - name: test connection    #自定义任务名称
     ping:     #使用 module: [options] 格式来定义一个任务
   - name: disable selinux
     command: '/sbin/setenforce 0'    #command模块和shell模块无需使用key=value格式
     ignore_errors: True     #如执行命令的返回值不为0,就会报错,tasks停止,可使用ignore_errors忽略失败的任务
   - name: disable firewalld
     service: name=firewalld state=stopped    #使用 module: options 格式来定义任务,option使用key=value格式
   - name: install httpd
     yum: name=httpd state=latest
   - name: install configuration file for httpd
     copy: src=/opt/httpd.conf dest=/etc/httpd/conf/httpd.conf    #这里需要一个事先准备好的/opt/httpd.conf文件
     notify: "restart httpd"    #如以上操作后为changed的状态时,会通过notify指定的名称触发对应名称的handlers操作
   - name: start httpd service
     service: enabled=true name=httpd state=started
  handlers:     #handlers中定义的就是任务,此处handlers中的任务使用的是service模块
   - name: restart httpd    #notify和handlers中任务的名称必须一致
     service: name=httpd state=restarted

Ansible在执行完某个任务之后并不会立即去执行对应的handler,而是在当前play中所有普通任务都执行完后再去执行handler,这样的好处是可以多次触发notify,但最后只执行一次对应的handler,从而避免多次重启。

1.2.1 运行playbook

ansible-playbook test1.yaml
//补充参数:
-k(–ask-pass):用来交互输入ssh密码
-K(-ask-become-pass):用来交互输入sudo密码
-u:指定用户
ansible-playbook test1.yaml --syntax-check    #检查yaml文件的语法是否正确
ansible-playbook test1.yaml --list-task       #检查tasks任务
ansible-playbook test1.yaml --list-hosts      #检查生效的主机
ansible-playbook test1.yaml --start-at-task='install httpd'     #指定从某个task开始运行

1.3 定义、引用变量

- name: second play
  hosts: dbservers
  remote_user: root
  vars:                 #定义变量(只在当前剧本生效)
   - groupname: mysql   

你可能感兴趣的:(ansible,apache,网络)