Ansible用法playbook

playbook文件

hello.yml
---
- name: test_tasks  【各个任务的总描述】
   hosts: webserver
   remote_user: root
  gather_facts: no

   tasks:
    - name: test1              【单个任务的描述】【一个- name里只能有一个模块的任务】
      command: hostname
    - name: test2               【单个任务的描述】
      command: ls /root
1、文件后缀名为.yml或.yaml【因为是用yaml语言编写】
2、文件开头以---标记【习惯而已,为了标准化】
在第一行也可加yaml解释器:#!/usr/bin/ansible-playbook;执行脚本时 ./test/yml;可省去ansibile-playbook test.yml
3、文件内容有严格的缩进控制
4、hosts: webserver 【后面有空格,冒号后面有空格】
5、remote_user: root 【表示执行任务的用户:root】
6、tasks:空一行,为了规范
7、gather_facts: no设置为No,表示运行playbook脚本不做采集主机的真相信息,可以更快速执行脚本
8、关键词都是冒号结尾的

  

ansible-vault

ansible-vault工具功能,管理加密解密playbook文件
1、ansible-vault [create | decrypt |encrypt| edit | rekey | view]
2、ansible-vault encrypt hello.yml 【加密】
3、ansible-vault decrypt hello.yml 【解密】
4、ansible-vault create hello.yml  【创建】
5、ansible-vault edit hello.yml     【编辑】
6、ansible-vault rekey hello.yml  【修改口令】
7、ansible-vault view hello.yml   【查看】

ansible-console

ansible-console工具,是一个交互式工具
1、直接输入ansible-console
2、root@all (2)[f:5]$  【root表示用户,all表示主机清单的所有主机,(2)表示主机清单有2台主机,[f:5]表示可并发执行5台主机】
3、root@all (2)[f:5]$ cd webserver   【进入到webserver主机组下】;cd 192.168.1.14 【进入到指定某个主机下】
4、root@all (2)[f:5]$ command hostname 【模块名+命令,即可直接执行】

palybook介绍

playbook是由一个或多个"play"组成的列表。
play的主要功能在于将事先归并为一组的主机装扮成事先通过ansible中的task定义好的角色。从根本上来讲,所谓task无非是
调用ansible的一个module;将多个play组织在一个playbook中,可以连同所有的play执行。
playbook采用YMAL 语言编写。

palybook核心元素

1、hosts 执行的远程主机列表
2、tasks 任务集
3、variables 内置变量或自定义变量在playbook中调用
4、templates 模板,可替换模板文件中的变量并实现一些简单逻辑的文件
5、handlers 和notity 必须结合使用,由特定的条件触发操作,notity通知>handlers执行
6、tags 标签 对某条任务名个别名,用于指定某条具体的任务执行:
      ansible-playbook -t tagsname fiel.yml 【指定tagsname此标签执行任务】

YAML语法简介

1、在单一脚本中,可以连续三个字号---区分
2、次行开始正常些playbook的内容,一般建议写明该playbook的功能【即标记name:】
3、使用#号注释
4、缩进必须是同一的,不能空格和tab混用
5、缩进的级别也必须是一致的,同样的缩进代表同样的级别,程序判别配置的级别是通过缩进和换行来实现的
6、YAML文件内容和linux系统大小写判断方式一致,区别大小写
7、k/v值可同一行写也可换行写,同一行使用:分隔,换行写使用-
8、v可以是一个字符串,也可是另一个列表
9、一个完整的代码块功能需最少元素包括 name 、tasks
10、一个name只能包括一个task
11、YAML文件扩展名通常为yml或yaml
- name: **
  hosts: **
  remote_user: **
  
  tasks:
    - name: **
      module: **
注意:所有和上一行的缩进必须保持相同的缩进量,如空格两个,则所有的以下的都必须是空格两个

  

playbook基础组件

 tasks:
    - name: test1              
      command: hostname
1、如上,任务的模块名为shell或command时,后面直接跟命令,而非key=value形式
2、如果命令或脚本退出码不为0即执行出错了,可以使用如下代替:
 tasks:
    - name: test1              
      command: command1 || command2
 或者使用ignore_errors来忽略错误信息:
 tasks:
    - name: test1              
      command: command1
      ignore_errors: True

  

运行playbook

1、运行方式:
ansible-playbook [filename.yml]  [options]
常见options:
    --check 只检测脚本语法,但不真正执行操作, -C 代替别名ansible-playbook [filename.yml] -C
    --list-hosts 列出运行任务的主机
    --limit hosts  只针对主机列表中的主机执行
    -v 显示过程 -vv -vvv更详细过程
    
2、举例:
ansible-playbook file.yml --check [或-C]
ansible-playbook file.yml --list-hosts
ansible-playbook file.yml --limit webserver
ansible-playbook file.yml -v [或-vv] [或-vvv]

3、ansible-playbook的新增功能参数:
--ask-vault-pass:   加密playbook文件时提示输入密码
-D :                即--diff:当更新的文件数及内容较少时,该选项可显示这些文件不同的地方,该选项结合-C用会有较好的效果
-e :                 -e var1=value1 在Playbook中引入外部变量
--flush-cache:       将清除fact到的远程主机缓存
--force-handlers:    强制运行handlers的任务,即使在任务失败的情况下
-i :                 -i inventory/init 指定要读取的主机清单文件init
--list-tags:         列出所有可用的tags
--list-tasks:        列出所有即将被执行的任务。
--skip-tags:         跳过指定的tags任务。
--start-at-task:     从第几条任务开始执行。
--step:              逐步执行Playbook定义的任务,并经人工确认后继续执行下一步任务。
--syntax-check:      检查Playbook中的语法书写。
-t TAGS, --tags=TAGS:指定执行该tags的任务
posted @ 2019-10-18 19:17  一尾  阅读(833)  评论(0编辑  收藏  举报