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 : 现实过程
ansible all --list-hosts 列出hosts
ansible all -m ping -v / -vv /-vvv #表示显示详细内容 v越多越详细
Playbook的核心组件
name 可选,建议使用多用于说明
hosts 受控主机列表
tasks 任务,用于选择执行部分代码
例如:
vim test.yml
---
- name: test play book
hosts: all
remote_user: root
tasks:
- name: check hosts
yum:
name=httpd
state=latest
- name: start httpd
service:
name=httpd
state=started
enabled=yes
测试如下:
ansible-playbook test.yml -C
#在执行playbook的时候,加上-C就可以只检测不执行
加上 --syntax-check 就是语法检测!
直接执行playbook就可以下载httpd服务并开启服务:
ansible-playbook test.yml
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