ansible之playbook

一、介绍

playbook(剧本): 是ansible⽤于配置,部署,和管理被控节点的剧本。⽤于ansible操作的编排。

使⽤的格式为yaml格式(saltstack,elk,docker,docker,compose,kubernetes等也都会⽤到yaml格式)

二、YMAL格式

1)以.yaml或.yml结尾

2)⽂件的第⼀⾏以 "---"开始,表明YMAL⽂件的开始(可选的)

3)以#号开头为注释

4)列表中的所有成员都开始于相同的缩进级别, 并且使⽤⼀个 "-" 作为开头(⼀个横杠和⼀个空格)

5)⼀个字典是由⼀个简单的 键: 值 的形式组成(这个冒号后⾯必须是⼀个空格)

6)注意: 写这种⽂件不要使⽤tab键,都使⽤空格

三、playbook实例

1. playbook编排vsftpd

[root@m0 ~]# vim test001.yml


  • hosts: group01 //⽤于指定要执⾏任务的主机,其可以是⼀个或多个由冒号分隔主机组.

remote_user: root //⽤于指定远程主机上的执⾏任务的⽤户

tasks: //任务列表, 按顺序执⾏任务,handlers: 类似task,但需要使⽤notify通知调⽤

  • name: 卸载vsftp

yum: name=vsftpd state=absent

  • name: 安装vsftpd

yum: name=vsftpd state=latest

  • name: 启动服务

service: name=vsftpd state=started enabled=yes

  • name: 修改配置文件

command: sed -i '/^anonymous_enable=YES/s/YES/NO/g' /etc/vsftpd/vsftpd.conf

notify:

  • abcdefg

handlers:

  • name: abcdefg

service: name=vsftpd state=restarted

[root@m0 ~]# ansible-playbook ./test001.yml //执行

2.修改httpd的端⼝为8080,再执⾏playbook测试

[root@m0 ~]# vim test002.yml


  • hosts: group01

remote_user: root

tasks:

  • name: 将管理机的rope文件复制到被控制主机

copy: src=/etc/yum.repos.d dest=/etc/

  • name: 安装httpd

yum: name=httpd state=present

  • name: 修改配置文件

command: sed -i '/^Listen/s/80/8080/g' /etc/httpd/conf/httpd.conf

  • name: 修改默认的资源文件

command: echo "xxxxxxx" > /var/www/html/index.html

  • name: 启动httpd服务

service: name=httpd state=started

[root@m0 ~]# ansible-playbook ./test002.yml

3.编排nfs搭建与客户端挂载

[root@m0 ~]# vim /etc/ansible/hosts

s1 ansible_ssh_host=192.168.1.68 ansible_ssh_port=22 ansible_ssh_user=root ansible_ssh_pass=q

s2 ansible_ssh_host=192.168.1.69 ansible_ssh_port=22 ansible_ssh_user=root ansible_ssh_pass=q

[root@m0 ~]# vim test003.yml


  • hosts: s1

remote_user: root

tasks:

  • name: 安装nfs-utils

yum: name=nfs-utils state=latest

  • name: 安装rpcbind

yum: name=rpcbind state=latest

  • name: 创建共享目录

file: path=/static state=directory

  • name: 配置文件

shell: echo '/static *(ro,sync)' > /etc/exports

  • name: 启动服务nfs

service: name=nfs state=started enabled=yes

  • name: 启动服务rpdbind

service: name=rpcbind state=started enabled=yes

  • hosts: s2

remote_user: root

tasks:

  • name: 安装nfs-utils

yum: name=nfs-utils state=latest

  • name: 创建挂载目录

file: path=/nfs state=directory

  • name: 挂载nfs文件

command: mount -t nfs 192.168.1.68:/static /nfs

[root@m0 ~]# ansible-playbook ./test003.yml

相关推荐
hhzz6 天前
Ansible自动化运维实战--通过role远程部署nginx并配置(8/8)
运维·自动化·ansible
_Eden_6 天前
Ansible入门学习之Playbook快速入门
学习·ansible
_Eden_6 天前
Ansible介绍与入门学习
运维·学习·ansible
hhzz8 天前
ansible自动化运维实战--fetch、cron和group模块(5)
运维·自动化·ansible
hhzz8 天前
ansible自动化运维实战--yaml的使用和配置(7)
运维·自动化·ansible
hhzz8 天前
ansible自动化运维实战--软件包管理模块、服务模块、文件模块和收集模块setup(4)
运维·自动化·ansible
hhzz10 天前
ansible自动化运维实战--script、unarchive和shell模块(6)
运维·自动化·ansible
蘑菇丁10 天前
ansible 批量按用户名创建kerberos主体,并分发到远程主机
大数据·服务器·ansible
阿无@_@11 天前
1、ceph的安装——方式一ceph-ansible
ceph·ansible
牙牙70511 天前
ansible一键安装nginx二进制版本
服务器·nginx·ansible