【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】

文章目录

    • ansible-playbook 剧本(1)
    • 核心元素:
    • playbook的基础组件:
    • 实战案例1 playbook 创建文件
    • 由特定条件触发的Tasks 触发器
    • 循环:迭代,需要重复执行的任务;固定变量名为”item
    • 案例四、自定义vars_files变量
    • 实战:通过playbook安装apache

ansible-playbook 剧本(1)

Playbook介绍

playbook是ansible用于配置,部署,和管理被控节点的剧本。通过playbook的详细描述,执行其中的tasks,可以让远端主机达到预期的状态。playbook是由一个或多个”play”组成的列表。 当对一台机器做环境初始化的时候往往需要不止做一件事情,这时使用playbook会更加适合。通过playbook你可以一次在多台机器执行多个指令。通过这种预先设计的配置保持了机器的配置统一,并很简单的执行日常任务。

ansible通过不同的模块实现相应的管理,管理的方式通过定义的清单文件(hosts)所管理的主机包括认证的方式连接的端口等。所有的功能都是通过调用不同的模块(modules)来完成不同的功能的。不管是执行单条命令还是play-book都是基于清单文件。

playbook格式

playbook由YMAL语言编写。YMAL格式是类似于JSON的文件格式,便于人理解和阅读,同时便于书写。
一个剧本里面可以有多个play,每个play只能有一个tasks,每个tasks可以有多个name

核心元素:

Playbooks
Variables #变量元素,可传递给Tasks/Templates使用;
Tasks #任务元素,由模块定义的操作的列表,即调用模块完成任务;
Templates #模板元素,使用了模板语法的文本文件;
Handlers #处理器元素,通常指在某事件满足时触发的操作;
Roles #角色元素

playbook的基础组件:

name:
定义playbook或者task的名称(描述信息),每一个play都可以完成一个任务。
hosts:
hosts用于指定要执行指定任务的主机.
user:
remote_user则用于指定远程主机上的执行任务的用户
tasks:
任务列表play的主体部分是task list. task list中的各任务按次序逐个在hosts中指定的所有主机上执行,即在所有主机上完成第一个任务后再开始第二个。
vars:
定义变量(如果不使用内部变量需要提前定义)
vars_files:
调用定义变量文件
notify:
任务执行结果如果是发生更改了的则触发定义在handler的任务执行
handlers:
用于当前关注的资源发生变化时采取一定指定的操作
【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第1张图片

实战案例1 playbook 创建文件

参数解释:
hosts: 参数指定了对哪些主机进行操作;
user: 参数指定了使用什么用户登录远程主机操作;
tasks: 指定了一个任务.
name:参数同样是对任务的描述,在执行过程中会打印出来。

创建文件,必须以 .yml 结尾或者 .yaml 结尾
[root@web1 playbook]# vim wenjian.yml

文件语法;

  • hosts: web2
    user: root
    tasks:
    • name: 创建一个文件
      file: path=/root/t.txt state=touch

检测语法是否合格; ansible-playbook --syntax-check wenjian.yml

playbook: wenjian.yml 合格语法

【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第2张图片
开始运行;ansible-playbook wenjian.yml 开始运行
【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第3张图片
测试有没有
【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第4张图片

由特定条件触发的Tasks 触发器

参数详解
handlers:由特定条件触发的Tasks
handlers:处理器
notify:触发器

[root@web1 playbook]# vim httpd.yml 编写文件

语法;

  • hosts: web2
    user: root
    tasks:
    • name: 安装httpd
      yum: name=httpd state=latest
      notify: start httpd 上面任务执行成功,然后通知他
      handlers:
    • name: start httpd 一一对应,这里的描述与notify定义的必须一样
      service: name=httpd state=started #4.执行这个命令

【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第5张图片
开始执行 测试
语法;ansible-playbook httpd.yml 开始测试
【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第6张图片
web2节点开始测试
语法;systemctl status httpd 查看 安装包状态
【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第7张图片
【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第8张图片

循环:迭代,需要重复执行的任务;固定变量名为”item

对迭代项的引用,固定变量名为”item”,使用with_item属性给定要迭代的元素;
语法
循环:迭代,需要重复执行的任务;
对迭代项的引用,固定变量名为”item”,使用with_item属性给定要迭代的元素;

基于字符串列表元素实战:
[root@ansible-server ansible]# vim list.yml

  • hosts: webservers2
    remote_user: root
    tasks:
    • name: install packages
      yum: name={{ item }} state=latest #相当于for循环里面的i
      with_items: #取值 。但是不支持通配符
      • httpd
      • php
      • php-mysql
      • php-mbstring
      • php-gd

语法;
vim nginx.yml 编写配置文件
语法;

  • hosts: web3
    user: root
    tasks:
    • name: 安装 httpd vim wegt
      yum: name={{ item }} state=latest
      with_items:
      • httpd
      • vim
      • wegt

【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第9张图片
开始检测语法;
检测语法;ansible-playbook --syntax -check nginx.yml

playbook: nginx.yml
在这里插入图片描述

案例四、自定义vars_files变量

变量调用语法:
{{ var_name }}
创建变量目录;
步骤;先创建变量目录

[root@ansible-server ~]# mkdir /root/playbook/bianlang.yml 目录自定义
[root@ansible-server ~]# cd /etc/ansible/vars/
[root@ansible-server vars]# vim file.yml #创建变量文件。
src_path: /root/test/a.txt 要拷贝那个文件 最好写绝对路径
dest_path: /opt/test/ 要拷贝到节点的那个目录
在这里插入图片描述

创建play-book引用变量文件:
语法;

  • hosts: web3
    user: root
    vars_files:
    • /root/playbook/bianlang.yml
      tasks:
    • name: 创建目录
      file: path={{ dest_path }} state=directory
    • name: 拷贝文件
      copy: src={{ src_path }} dest={{ dest_path }}

【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第10张图片
语法检测 执行
[root@web1 playbook]# ansible-playbook --syntax -check 4.yml

playbook: 4.yml
[root@web1 playbook]# ansible-playbook 4.yml
【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第11张图片
【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第12张图片

实战:通过playbook安装apache

安装 httpd 并修改端口号
自己主机 先安装httpd 拷贝httpd 配置文件 修改端口

步骤1;yum install -y httpd
步骤2;[root@ansible-server ~]# cp /etc/httpd/conf/httpd.conf /root/ #将配置文件推送到web3
3.修改端口将原来的80修改为8080

然后去编写剧本
语法;

  • hosts: web2
    user: root
    tasks:
    • name: 安装httpd
      yum: name=httpd state=latest
    • name: 拷贝端口文件
      copy: src=/root/httpd.conf dest=/etc/httpd/conf/httpd.conf
      notify: start httpd
      handlers:
    • name: start httpd
      service: name=httpd state=started
      【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第13张图片
      测试 语法 开始运行
      步骤1;[root@web1 playbook]# ansible-playbook --syntax -check 5.yml

playbook: 5.yml
步骤2;[root@web1 playbook]# ansible-playbook 5.yml
【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第14张图片
节点测试
【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第15张图片
【企业级自动化运维神器/工具Ansible】【ansible-playbook 剧本(1)重点】【单个剧本】【触发器剧本】【循环:迭代juben】【变量vars_files剧本】_第16张图片

你可能感兴趣的:(云计算方向二,运维,数据库,ruby)