playbook(剧本)基本应用、playbook常见语法、playbook和ansible操作的编排

playbook(剧本):

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

使⽤的格式为yaml格式

一、YMAL格式

以.yaml或.yml结尾 ⽂件的第⼀⾏以 "---"开始,表明YMAL⽂件的开始(可选的)

以#号开头为注释

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

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

二、playbook基本应用

第1步: 创建⼀个存放playbook的⽬录(路径⾃定义)

mkdir /etc/ansible/playbook

第2步: 准备httpd配置⽂件,并修改成你想要的配置

安装httpd

yum -y install httpd

启动httpd服务

systemctl start httpd

可根据需求对下面配置文件进行修改

vim /etc/httpd/conf/httpd.conf

第3步:修改hosts文件

root@mo \~\]#vim /etc/ansible/hosts s0 ansible_ssh_host=192.168.1.25 ansible_ssh_port=22 ansible_ssh_user=root ansible_ssh_pass=1 s1 ansible_ssh_host=192.168.1.26 ansible_ssh_port=22 ansible_ssh_user=root ansible_ssh_pass=1 s2 ansible_ssh_host=192.168.1.27 ansible_ssh_port=22 ansible_ssh_user=root ansible_ssh_pass=1 \[s

s0
s1
s2
第4步: 写⼀个playbook⽂件(后缀为.yml或.yaml)

root@mo \~\]# vim test001.yml ![](https://i-blog.csdnimg.cn/direct/313ad0cb2a174c788bb0235de0e4887d.png) 第5步: 执⾏写好的palybook \[root@mo \~\]#ansible-playbook ./test001.yml 会显示出执⾏的过程,并且执⾏的每⼀步都有ok,changed,failed等标识 执⾏如果有错误(failed)会回滚,解决问题后,直接再执⾏这条命令即可,并会把failed改为changed(幂等性) 三、playbook常⻅语法 hosts: ⽤于指定要执⾏任务的主机,其可以是⼀个或多个由冒号分隔主机组. remote_user: ⽤于指定远程主机上的执⾏任务的⽤户. tasks: 任务列表, 按顺序执⾏任务. handlers: 类似task,但需要使⽤notify通知调⽤。 注:不管有多少个通知者进⾏了notify,等到play中的所有task执⾏完成之后,handlers也只会被执⾏⼀次. handlers最佳的应⽤场景是⽤来重启服务,或者触发系统重启操作.除此以外很少⽤到了. nfs相关配置 安装nfs yum -y install nfs-utils 创建挂载目录 mkdir /nfs 挂载 mount -t nfs 192.168.1.25:/static /nfs/ 验证: \[root@dd \~\]# systemctl status nfs ![](https://i-blog.csdnimg.cn/direct/03905f1c061845fb82af7f9d46e39a6c.png) \[root@dd \~\]# systemctl status rpcbind ![](https://i-blog.csdnimg.cn/direct/7ae30b1899cc4aae921ea22d962c8358.png) 卸载nfs ansible s -m yum -a 'name=nfs-utils state=absent' #### 四、playbook编排vsftpd \[root@mo \~\]# vim test001.yml ![](https://i-blog.csdnimg.cn/direct/01a2ed27f04e47859ef6a74a3dd5ecc2.png) 执行文件 \[root@mo \~\]#ansible-playbook ./test001.yml #### 五、修改httpd端口并测试 修改httpd的端⼝为8080,再执⾏playbook测试 编辑yml文件 \[root@mo \~\]# vim test002.yml ![](https://i-blog.csdnimg.cn/direct/7b4b2d33bc7149918c5347006992a7d6.png) 执行文件 \[root@mo \~\]#ansible-playbook ./test002.yml ![](https://i-blog.csdnimg.cn/direct/ed70d5991c774549831b819690c9ad56.png) #### 六、playbook编排多个hosts任务 编辑yml文件 \[root@mo \~\]# vim test002.yml ![](https://i-blog.csdnimg.cn/direct/360dcb8880564e3c9df9baa743650ec7.png) 执行文件 \[root@mo \~\]#ansible-playbook ./test002.yml 七、编排nfs搭建与客户端挂载 1.准备nfs配置文件 \[root@mo \~\]# vim /etc/exports /static \*(ro,sync) 2,.编写yml编排⽂件 \[root@mo \~\]# vim test003.yml ![](https://i-blog.csdnimg.cn/direct/4602b43aa1f14c269dbb304f9f276b0f.png) 3.执行playbook \[root@mo \~\]# ansible-playbook ./test003.yml ![](https://i-blog.csdnimg.cn/direct/5ab4b53e3b0a4bdf8936ac99f713702c.png)

相关推荐
Aurora_NeAr1 小时前
Apache Iceberg数据湖基础
apache
Antonio9152 小时前
【音视频】HLS简介与服务器搭建
运维·服务器·音视频
源图客2 小时前
Apache Nutch介绍与部署编译
apache·nutch
kfepiza2 小时前
Debian的`/etc/network/interfaces`的`allow-hotplug`和`auto`对比讲解 笔记250704
linux·服务器·网络·笔记·debian
FreeBuf_2 小时前
Apache组件遭大规模攻击:Tomcat与Camel高危RCE漏洞引发数千次利用尝试
java·tomcat·apache
无妄-20243 小时前
软件架构升级中的“隐形地雷”:版本选型与依赖链风险
java·服务器·网络·经验分享
R.X. NLOS3 小时前
VS Code远程开发新方案:使用SFTP扩展解决Remote-SSH连接不稳定问题
运维·服务器·ssh·debug·vs code
轩情吖7 小时前
Qt的第一个程序(2)
服务器·数据库·qt·qt creator·qlineedit·hello world·编辑框
jingyu飞鸟7 小时前
linux系统源代码安装apache、编译隐藏版本号
linux·运维·apache
世事如云有卷舒7 小时前
Ubunt20.04搭建GitLab服务器,并借助cpolar实现公网访问
linux·服务器·gitlab