使用Ansible中的Playbook
一、Playbook的功能
playbook 是由一个或多个play组成的列表
Playboot 文件使用YAML来写的
二、YAML
1.简介
是一种表达资料序列的格式,类似XML
Yet Another Markup Language
2001年首次发表
www.yaml.org
2.特点
可读性好
和脚本语言交互性号
易于实现
适用程序执行流梳理方式
可扩展性强
3.语法简介
在文件中用[—]开始
在文件中用[…]结尾
次行一般书写文件内容
缩进严格
大小写敏感
key/value可以多行书写也可一行书写,一行书写用,隔开
value可以是个字符串,也可是list
一个play需要包括name和tasks
name 是描述
tasks 是动作
一个name只能包含一个task
扩展名称yml或者yaml
4.YAML 列表
两种书写方式
[Linux,C++,Java,Python]
- Linux
- C++
- Java
- Python
5.YAML的字典
字典作用存放键值
name:westos
age:12
jobs:linux
{name: "westos", age: "12", jobs: "linux"}
三、playbook执行命令
ansible-playbook xxx.yml ...
--check|-C ##检测
--syntax-check ##check language
--list-hosts ##列出hosts
--list-tags ##列出tag
--list-tasks ##列出task
--limit ##指定执行主机
-v -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
vim 设定技巧
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
五、练习,设置匿名用户可以访问vsftps
vim test.yml #配置文件
---
- name: vsftpd anon yes #总名称
hosts: all #受控设置
tasks:
- name: install vsftpd #安装vsftpd服务
dnf:
name: vsftpd
state: present
- name: set firewalld #设置仿火墙
firewalld:
permanent: yes #永久生效
state: enabled #开启
immediate: yes #立即生效
service: ftp #服务名称
- name: configure vsftpd.conf #修改配置文件,设置匿名用户可以访问
lineinfile:
path: /etc/vsftpd/vsftpd.conf #指定配置文件目录
regexp: anonymous_enable=NO #替换
line: anonymous_enable=YES #替换结果
- name: start vsftpd #重启服务
service:
name: vsftpd
state: restarted
enabled: yes
ansible-playbook test.yml #运行文件test.yml