【Ansible】playbook 剧本

本文详细介绍了Ansible的playbook剧本,包括playbooks的组成部分,如定义变量、sudo切换用户、when条件判断和迭代。重点讨论了Templates模块,如何创建.j2模板文件并引用变量,以及Roles模块,解释了roles的目录结构和使用步骤,同时展示了如何编写httpd、mysql和php模块。
摘要由CSDN通过智能技术生成

目录

playbook 剧本

playbooks 本身由以下各部分组成

定义、引用变量

指定远程主机sudo切换用户

when条件判断

迭代

Templates 模块

1.先准备一个以 .j2 为后缀的 template 模板文件,设置引用的变量

2.修改主机清单文件,使用主机变量定义一个变量名相同,而值不同的变量

3.编写 playbook 

tags 模块

用剧本安装lnmp

Roles 模块

roles 的目录结构:

roles 内各目录含义解释

在一个 playbook 中使用 roles 的步骤:

编写httpd模块

编写mysql模块

编写php模块

编写roles示例


playbook 剧本

playbooks 本身由以下各部分组成

(1)Tasks:任务,即通过 task 调用 ansible 的模板将多个操作组织在一个 playbook 中运行
(2)Variables:变量
(3)Templates:模板
(4)Handlers:处理器,当changed状态条件满足时,(notify)触发执行的操作
(5)Roles:角色

示例

vim test1.yaml
---     #yaml文件以---开头,以表明这是一个yaml文件,可省略
- name: first play       #定义一个play的名称,可省略
  gather_facts: false    #设置不进行facts信息收集,这可以加快执行速度,可省略
  hosts: webservers      #指定要执行任务的被管理主机组,如多个主机组用冒号分隔
  remote_user: root      #指定被管理主机上执行任务的用户
  tasks:                 #定义任务列表,任务列表中的各任务按次序逐个在hosts中指定的主机上执行
   - name: test connection           #自定义任务名称
     ping:                           #使用 module: [options] 格式来定义一个任务
   - name: disable selinux
     command: '/sbin/setenforce 0'   #command模块和shell模块无需使用key=value格式
     ignore_errors: True             #如执行命令的返回值不为0,就会报错,tasks停止,可使用ignore_errors忽略失败的任务
   - name: disable firewalld
     service: name=firewalld state=stopped    #使用 module: options 格式来定义任务,option使用key=value格式
   - name: install httpd
     yum: name=httpd state=latest
   - name: install configuration file for httpd
     copy: src=/opt/httpd.conf dest=/etc/httpd/conf/httpd.conf    #这里需要一个事先准备好的/opt/httpd.conf文件
     notify: "restart httpd"    #如以上操作后为changed的状态时,会通过notify指定的名称触发对应名称的handlers操作
   - name: start httpd service
     service: enabled=true name=httpd state=started
  handlers:               #handlers中定义的就是任务,此处handlers中的任务使用的是service模块
   - name: restart httpd    #notify和handlers中任务的名称必须一致
     service: name=httpd state=restarted
##Ansible在执行完某个任务之后并不会立即去执行对应的handler,而是在当前play中所有普通任务都执行完后再去执行handler,这样的好处是可以多次触发notify,但最后只执行一次对应的handler,从而避免多次重启。
- name: the first play for install apache
  gather_facts: false
  hosts: dbservers
  remote_user: root
  tasks:
  - name: disable firewalld
    service: name=firewalld state=stopped enabled=no
  - name: disable selinux
    command: '/usr/sbin/setenforce 0'
    ignore_errors: true
  - name: disable selinux forever
    replace: path=/etc/selinux/config  regexp="enforcing"  replace="disabled"
  - name: mount cdrom
    mount: src=/dev/sr0 path=/mnt fstype=iso9660 state=mounted
  - name: copy local yum configuration file
    copy: src=/etc/yum.repos.d/repo.bak/local.repo  dest=/etc/yum.repos.d/local.repo
  - name: install apache
    yum: name=httpd state=latest
  - name: prepare httpd configuration file
    copy: src=/etc/ansible/playbook/httpd.conf dest=/etc/httpd/conf/httpd.conf
    notify: "reload httpd"
  - name: start apache
    service: name=httpd state=started enabled=yes

  handlers: 
  - name: reload httpd
    service: name=httpd state=reloaded


运行playbook

ansible-playbook demo1.yaml

 在另一台机器上就会发现apache已经安装,并暴露出端口号

netstat -lntp | grep 80
tcp6       0      0 :::80                   :::*                    LISTEN      11454/httpd

补充参数
-k(–ask-pass):用来交互输入ssh密码
-K(-ask-become-pass):用来交互输入sudo密码
-u:指定用户
ansible-playbook test1.yaml --syntax-check                         #检查yaml文件的语法是否正确
ansible-playbook test1.yaml --list-task                                  #检查tasks任务
ansible-playbook test1.yaml --list-hosts                                #检查生效的主机
ansible-playbook test1.yaml --start-at-task='install httpd'     #指定从某个task开始运行

定义、引用变量

- name: second play
  hosts: dbservers
  remote_user: root
  vars:                 #定义变量
   - groupname: mysql   #格式为 key: value
   - username: nginx
  tasks:
   - name: create group
     group: name={
  {groupname}} system=yes gid=306    #使用 {
  {key}} 引用变量的值
   - name: create user
     user: name={
  {username}} uid=306 group={
  {groupname}} 
   - name: copy file
     copy: content="{
  {ansible_default_ipv4}}" dest=/opt/vars.txt    #在setup模块中可以获取facts变量信息

示例

- name: second play
  hosts: dbservers
  remote_user: root
  become: yes
  become_user: zxr
  vars:
  - username: ggl
  - groupname: zxr
  - filename: /opt/ggl.txt
  - uid: 1234
  gather_facts: true
  tasks:
  - name: create group
    group: name={
  {groupname}}  gid=1314
  - name: create user join group
    user: name={
  {username}} uid={
  {uid}} groups={
  {groupname}}
  - name: copy file
    copy: content="{
  {ansible_default_ipv4.address}}" dest={
  {filename}}
  - name: modify username and groupname of file
    file: path={
  {filename}} owner={
  {username}}  group={
  {groupname}}

 在另一个主机上输入id ggl

id ggl
uid=1234(ggl) gid=1234(ggl) 组=1234(ggl),1314(zxr)

在外面传参

ansible-playbook test1.yaml -e "username=nginx"     #在命令行里定义变量

在另一个主机上输入id nginx

id nginx
uid=1235(nginx) gid
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值