Playbook
1.Playbook的功能
playbook 是由一个或多个play组成的列表
Playbook 文件使用YAML来写的
2.YAML
#简介#
是一种表达资料序列的格式,类似XML
Yet Another Markup Language
2001年首次发表
www.yaml.org
#特点如下:
可读性好
和脚本语言交互性号
易于实现
适用程序执行流梳理方式
可扩展性强
#语法简介#
在文件中用[---]开始
在文件中用[...]结尾
次行一般书写文件内容
缩进严格
大小写敏感
key/value可以多行书写也可一行书写,一行书写用,隔开
value可以是个字符串,也可是list
一个play需要包括name和tasks
name 是描述
tasks 是动作
一个name只能包含一个task
扩展名称yml或者yaml
#YAML 列表#
[Linux,C++,Java,Python]
- Linux
- C++
- Java
- Python
#YAML的字典#
字典作用存放键值
name:westos
age:12
jobs:linux
{name: "westos", age: "12", jobs: "linux"}
playbook执行命令
在用ansible执行playbook的时候:
后面可以加的参数及其意义如下:
ansible-playbook xxx.yml --xx -x
–check | -C : 检测
–syntax-check : check language
–list-hosts : 列出hosts
–list-tags : 列出tag
–list-tasks : 列出task
–limit : 指定执行主机
-v -vv : 现实过程
加-c为检测:
ansible all --list-hosts 列出hosts
ansible all -m ping -v / -vv /-vvv表示显示详细内容!
当-vv表示更加详细!
Playbook的核心组件
name 可选,建议使用多用于说明
hosts 受控主机列表
tasks 任务,用于选择执行部分代码
例如:
---
- name: test play book
hosts: all
remote_user: root
tasks:
- name: check hosts
dnf:
name=httpd
state=latest
- name: start httpd
service:
name=httpd
state=started
enabled=yes
...
测试如下:
在执行playbook的时候,加上-c就可以只检测不执行!!
加上 --syntax-check 就是语法检测!
直接执行playbook就可以下载httpd服务并开启服务:
因为229已经下载过,所以绿色表示跳过!
129黄色表示下载成功,开启服务成功!
vim 设定技巧
vim ~/.vimrc如下:
autocmd FileType yaml setlocal ai ts=2 sw=2 et
setlocal ##设定当前文件
ai ##自动退格对齐 auto indent
ts ##tab建长度为2空格 tabstop=2
sw ##缩进长度为2 shiftwidth=2
et ##把tab键变成空格 expandtab