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

相关推荐
傻啦猫@_@5 天前
如何使用ansible上的A用户操作其它服务上的B用户目录下的文件
ansible
Sweety丶╮7945 天前
【Ansible】将文件部署到受管主机知识点
云原生·ansible
Anthony_2316 天前
Ansible的 Playbook 模式详解
linux·运维·服务器·ansible
野奔在山外的猫6 天前
【教程】Ansible 环境部署
ansible
泡沫冰@6 天前
实施Ansible Playbook
ansible
鲸屿1959 天前
Ansible之playbook
服务器·网络·ansible
Sweety丶╮7949 天前
【Ansible】的介绍
云原生·ansible
知白守黑2679 天前
Ansible角色
运维·服务器·ansible
Sweety丶╮79410 天前
【Ansible】实施 Ansible Playbook知识点
服务器·云原生·ansible
YC运维11 天前
Ansible题目全解析与答案
java·算法·ansible