1.创建roles文件夹

mkdir roles

2.在roles文件夹里面创建文件夹

  cd roles/

  mkdir {nginx,uwsgi,redis,mysql}

3.cd nginx

4.mkdir tasks/

5.cd tasks/

6.vi install.yml

- name: install
yun:name=nginx

vi copyfile.yml

- name : copyfile
template:src=nginx.conf dest=/etc/nginx/nginx.conf

vi start.yml

- name: start
service:name=nginx state=started enabled=yes

vi main.yml

- import_tasks: install.yml
- import_tasks: copyfile.yml
- import_tasks: start.yml

7.在nginx目录下安装nginx            yum install -y nginx

8. 创建一个templates目录,和tasks目录同级   mkdir templates

9.cd templates/

10.cp /etc/nginx/nginx.conf .   将nginx配置文件拷贝到templtes文件夹下

ansible 127.0.0.1 -m setup -a "filter=*process*"   #查询cpu个数

11.vi nginx.conf

  #改变两个参数

  worker_processes {{ansible_processor_vapus*2}}       #这里设置为cpu的个数或者cpu个数的两倍

   events{

                 worker_connections 102400;                  #这是连接数,可以调大

}

  server{   #介绍

    listen# 第一个监听ipv4

    listen #第二个监听ipv6
}

12.如果不需要传变量需要创建一个files的目录,和tasks在同一级目录下

mkdir files

以下是实例

  cd files/

  echo "test">>c.txt

  cd ..

  vi tasks/main.yml

- name :file
copy:dest=/tmp/aaa.txt src=c.txt

13.如果要是传变量的话,在tasks的同级目录下创建一个vars的目录

mkdir vars

vi vars/main.yml

{"user":alex}

vi tasks/main.yml

- name:createuser
user: name={{user}}

14.使用handler同样需要在tasks的同级目录下创建handlers目录

mkdir handlers

vi handlers/main.yml

- name: restartngnx
service: name=nginx state=restarted

vi tasks/main.yml

  notify:restart   #用来触发handlers

15.在roles平级的目录下

vi nginx.yml

- hosts : web
roles:
- nginx
#web是一个ip组的名称相当于一个ip

16.ansible-playbook --syntax-chek nginx.yml   测试代码没有问题

17.ansible-playbook  nginx.yml   启动代码

18. vi roles/nginx/templates/nginx.conf 

server{
listen 80;
listen [::]:80; #改这两个参数
}
roles

- 目录结构清晰
- 可以相互调用 - import_tasks: roles/nginx/tasks/install.yml
- 备份方便 解耦 ```
roles/nginx/
├── files -- 静态文件
│   └── c.txt
├── handlers -- 触发的任务
│   └── main.yml
├── tasks -- 任务(必须的)
│   ├── copyfile.yml
│   ├── install.yml
│   ├── main.yml
│   └── start.yml
├── templates -- 动态文件,需要传递参数
│   └── nginx.conf
└── vars -- 变量
└── main.yml ``` 查找顺序 - 主文件看到roles,就回去roles目录下面找对应的目录
- 先去tasks目录里面找main.yml文件,如果遇到import_task则加载任务
- 如果遇到了template,则去templates目录里面找文件
- 如果遇到了copy,则去files目录里面找文件
- 如果遇到了变量,则去vars目录里面找main.yml文件
- 如果遇到了notify,则去handlers目录里面找main.yml文件

互相调用(uwsgi调用nginx的安装程序nginx.yml)

1.cd roles/uwsgi/

2.vi tasks/main.yml

- import_tasks:roles/nginx/tasks/install.yml

3.在roles同级目录下

vi uwsgi.yml

-hosts:web
roles:
- uwsgi
#web是一个ip组的名称相当于一个ip

4.ansible-playbook uwsgi.yml    启动文件

这样就调用成功

ansible的roles使用的更多相关文章

  1. Ansible的roles标准化与Jenkins持续集成(三)

    Ansible的roles标准化与Jenkins持续集成(三) 链接:https://pan.baidu.com/s/1A3Iq3gGkGS27L_Gt37_I0g 提取码:ncy2 复制这段内容后打 ...

  2. Ansible:roles初始化系统

    简介 本文介绍ansible的roles,通过roles来实现系统的初始化,其相当于将ansible的playbook拆分.本文通过Jenkins,传参,调用playbook来初始化系统. Githu ...

  3. Ansible之roles模块--lnmp分布式部署

    Ansible之roles模块--lnmp分布式部署 目录 Ansible之roles模块--lnmp分布式部署 1. role模块的作用 2. roles的目录结构 3. roles内个目录含义解释 ...

  4. ansible基础-roles

    一 简介 注:本文demo使用ansible2.7稳定版 在我看来,role是task文件.变量文件.handlers文件的集合体,这个集合体的显著特点是:可移植性和可重复执行性. 实践中,通常我们以 ...

  5. Git+Gitlab+Ansible的roles实现一键部署Nginx静态网站(一)--技术流ken

    前言 截止目前已经写了<Ansible基础认识及安装使用详解(一)--技术流ken>,<Ansible常用模块介绍及使用(二)--技术流ken><Ansible剧本介绍及 ...

  6. Ansible playbook roles

    1  概述 角色(roles):如果我们使用playbook写成一个文件,这个文件会很大,但是不方便组织,我们可以分组,把playbook根据功能,如handler,tasks等分门别类的放在在各自的 ...

  7. Ansible Playbook Roles and Include Statements

    介绍 虽然可以在一个非常大的文件中编写一个playbook(您可能会以这种方式开始学习playbook),但最终您将需要重新使用文件并开始组织事情. 在基本级别,饱含任务的文件允许您将配置策略分解成较 ...

  8. Ansible之roles角色

    一.roles简介 ansible自1.2版本引入的新特性,用于层次性.结构化地组织playbook.roles能够根据层次型结构自动装载变量文件.tasks以及handlers等.要使用roles只 ...

  9. ansible 模块 roles

    setup 作用,用来查看用看内部的详细信息 ansible_all_ipv4_addresses # ipv4的所有地址 ansible_all_ipv6_addresses # ipv6的所有地址 ...

  10. 自动化运维工具Ansible之Roles测验详解

    Ansible Roles 详解与实战案例 主机规划 添加用户账号 说明: 1. 运维人员使用的登录账号: 2. 所有的业务都放在 /app/ 下「yun用户的家目录」,避免业务数据乱放: 3. 该用 ...

随机推荐

  1. java对象的克隆以及深拷贝与浅拷贝

    一.为什么要使用克隆 在实际编程过程中,我们常常要遇到这种情况:有一个对象A,在某一时刻A中已经包含了一些有效值,此时可能 会需要一个和A完全相同新对象B,并且此后对B任何改动都不会影响到A中的值,也 ...

  2. java-字节流-字符流

    I/O叙述 FileOutputStream类字节输出流的介绍: 写入数据的原理 java程序-->JVM(java虚拟机)--->OS(操作系统)---->OS调用写数据的方法-- ...

  3. memcached 能够更有效地使用内存吗?

    Memcache 客户端仅根据哈希算法来决定将某个 key 存储在哪个节点上,而不考 虑节点的内存大小.因此,您可以在不同的节点上使用大小不等的缓存.但是一 般都是这样做的:拥有较多内存的节点上可以运 ...

  4. SpringDataJpa备忘录

    单向多对一关系 //产品类型 一的一方 @Entity public class ProductDir { @Id @GeneratedValue private Long id; private S ...

  5. (stm32f103学习总结)—独立看门狗(IWDG)

    一.IWDG介绍 1.1 IWDG简介 STM32F1芯片内部含有两个看门狗外设,一个是独立看门狗IWDG,另 一个是窗口看门狗WWDG.两个看门狗外设(独立和窗口)均可用于检测 并解决由软件错误导致 ...

  6. 使用Vue2+webpack+Es6快速开发一个移动端项目,封装属于自己的jsonpAPI和手势响应式组件

    导语 最近看到不少使用vue制作的音乐播放器,挺好玩的,本来工作中也经常使用Vue,一起交流学习,好的话点个star哦 本项目特点如下 : 1. 原生js封装自己的跨域请求函数,支持promise调用 ...

  7. nodejs 实现 磁力链接资源搜索 BT磁力链接爬虫

    项目简介 前端站点 项目效果预览 http://findcl.com 使用 nodejs 实现磁力链接爬虫 磁力链接解析成 torrent种子信息,保存到数据库,利用 Elasticsearch 实现 ...

  8. TextView显示html样式的文字

    项目需求: TextView显示一段文字,格式为:白雪公主(姓名,字数不确定)向您发来了2(消息个数,不确定)条消息 这段文字中名字和数字的长度是不确定的,还要求名字和数字各自有各自的颜色. 一开始我 ...

  9. java中Array(数组)的用法

    8.Array(数组)    数组是作为对象来实现的.(really occupy the memopry,真实的占用内存 ) An array is a data structure that st ...

  10. 【001】学习前提——安装linux虚拟机,搭建docker

    1. 配置linux 1.1 修改配置 安装virtualbox的过程略过. 进入cd /etc/sysconfig/network-scripts,编辑:vi ifcfg-enp0s3 1>将 ...