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

相关推荐
我的运维人生15 小时前
利用Python与Ansible实现高效网络配置管理
网络·python·ansible·运维开发·技术共享
qlau200715 小时前
基于kolla-ansible在AnolisOS8.6上部署all-in-one模式OpenStack-Train
ansible·openstack
Shenqi Lotus1 天前
Ansible——Playbook基本功能
运维·ansible·playbook
qlau20074 天前
基于kolla-ansible在openEuler 22.03 SP4上部署OpenStack-2023.2
ansible·openstack
水彩橘子4 天前
Semaphore UI --Ansible webui
ui·ansible
happy_king_zi4 天前
ansible企业实战
运维·ansible·devops
码上飞扬4 天前
深入浅出 Ansible 自动化运维:从入门到实战
运维·ansible·自动化运维
theo.wu5 天前
Ansible自动化部署kubernetes集群
kubernetes·自动化·ansible
xidianjiapei0015 天前
Ubuntu Juju 与 Ansible的区别
linux·ubuntu·云原生·ansible·juju
打败4045 天前
ansible_find模块
linux·ansible