Roles小技巧:

1.创建roles目录结构,手动或使用ansible-galaxy init test roles

2.编写roles的功能,也就是tasks。 nginx rsyncd memcached

3.最后playbook引用roles编写好的tasks

1.创建标准roles目录结构
mkdir /root/roles/nginx/{tasks,templates,handlers} 2.编写tasks
[root@manager ~]# cat /root/roles/nginx/tasks/main.yml
- name: Install Nginx Server
yum:
name: nginx
state: present - name: Configure Nginx Server
template:
src: nginx.conf.j2
dest: /etc/nginx/nginx.conf
notify: Restart Nginx Server - name: Systemd Nginx Server
systemd:
name: nginx
state: started
enabled: yes 3.template
[root@manager roles]# cat /root/roles/nginx/templates/nginx.conf.j2
user www;
worker_processes {{ ansible_processor_vcpus }}; error_log /var/log/nginx/error.log notice;
pid /var/run/nginx.pid; events {
worker_connections {{ ansible_processor_vcpus * 1024 }};
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main; sendfile on;
#tcp_nopush on;
keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf;
} 4.handlers
[root@manager ~]# cat /root/roles/nginx/handlers/main.yml
- name: Restart Nginx Server
systemd:
name: nginx
state: restarted 5.调用playbook
[root@manager roles]# cat /root/roles/site.yml
- hosts: webservers
roles:
- nginx PS:hosts ansible.cfg 提前需准备好

实战一:roles部署memcached

#安装
#配置
#启动 1.创建roles的目录结构
[root@manager roles]# mkdir memcached/{tasks,templates,handlers} -p 2.编写对应的tasks (1.安装 2配置(templates) 3.启动 4.重启(handlers) )
[root@manager roles]# cat memcached/tasks/main.yml
- name: Installed Memecached Server
yum:
name: memcached
state: present - name: Configure Memcached Server
template:
src: memcached.j2
dest: /etc/sysconfig/memcached
notify: Restart Memcached Server - name: System Memcached Server
systemd:
name: memcached
state: started
enabled: yes 3.配置jinja2
[root@manager roles]# cat memcached/templates/memcached.j2
PORT="11211"
USER="memcached"
MAXCONN="1024"
CACHESIZE="{{ ansible_memtotal_mb //2 }}"
OPTIONS="" 4.handlers
[root@manager roles]# cat memcached/handlers/main.yml
- name: Restart Memcached Server
systemd:
name: memcached
state: restarted 5.playbook调用roles
[root@manager roles]# cat site.yml
- hosts: webservers
roles:
- { role: nginx, tags: web }
- { role: memcached, tags: cache }

实战二:部署NFS存储服务

#1.创建项目目录结构   --->
[root@manager roles]# mkdir nfs/{tasks,templates,handlers} -p #2.编写task任务 #3.playbook调用roles项目 [root@ansible roles]# tree nfs/
nfs/
├── handlers
│ └── main.yml
├── tasks
│ └── main.yml
└── templates
└── exports.j2 1.tasks编写
[root@ansible nfs]# cat tasks/main.yml
- name: Installed NFS Server
yum:
name: nfs-utils
state: present - name: Configure NFS Server
template:
src: exports.j2
dest: /etc/exports
notify: Restart NFS Server - name: Create NFS Server Share Directory
file:
path: "{{ nfs_word }}"
state: directory
owner: "{{ nfs_user }}"
group: "{{ nfs_user }}"
mode: '0755'
recurse: yes - name: Started NFS Server
systemd:
name: nfs
state: started
enabled: yes 2.触发重启,配置handlers
[root@ansible nfs]# cat handlers/main.yml
- name: Restart NFS Server
systemd:
name: nfs
state: restarted 3.调用roles项目
[root@ansible roles]# cat site.yml
- hosts: nfsservers
roles:
- { role: nfs, tags: nfs }

实战三:roles部署LB

1.nginxProxy+keepalived 10.0.0.5 10.0.0.6 10.0.0.3

2.nginx静态网站 172.16.1.7 172.16.1.8

1.web编写tasks任务
[root@manager web]# cat tasks/main.yml
#1.安装nginx服务
- name: Install nginx Server
yum:
name: nginx
state: present #2.创建用户组
- name: Create group
group:
name: "{{ user }}"
gid: "{{ uid }}" #3.创建用户
- name: create user
user:
name: "{{ user }}"
uid: "{{ uid }}"
group: "{{ user }}"
create_home: no
shell: /sbin/nologin #4.创建站点目录
- name: Create code directory
file:
path: "{{ code }}"
owner: "{{ user }}"
group: "{{ user }}"
mode: 0755
recurse: yes #5.配置nginx
- name: Configure Nginx Server
template:
src: "{{ item.src }}"
dest: "{{ item.dest }}"
mode: "{{ item.mode }}"
with_items:
- { src: nginx.conf.j2, dest: /etc/nginx/nginx.conf, mode: '0644' }
- { src: index.html, dest: /code, mode: '0644' }
- { src: web.conf.j2, dest: /etc/nginx/conf.d/web.conf, mode: '0644' }
notify: Restart nginx Server #6.启动nginx服务
- name: Systemd Nginx Server
systemd:
name: nginx
state: started 2.handlers触发重启nginx
[root@manager web]# cat handlers/main.yml
- name: Restart nginx Server
systemd:
name: nginx
state: restarted 3.准备j2文件
[root@manager roles]# tree web/
web/
├── handlers
│ └── main.yml
├── tasks
│ └── main.yml
└── templates
├── index.html
├── nginx.conf.j2
└── web.conf.j2 4.LB编写tasks任务
[root@manager lb]# cat tasks/main.yml
- name: Intalled Nginx Server
yum:
name: "{{ packages }}"
state: present
vars:
packages:
- nginx
- keepalived - name: Create shell share directory
file:
path: "{{ script }}"
state: directory - name: Configure nginx server
template:
src: "{{ item.src }}"
dest: "{{ item.dest }}"
mode: "{{ item.mode }}"
with_items:
- { src: nginx.conf.j2, dest: /etc/nginx/nginx.conf, mode: '0644' }
- { src: keepalived.conf.j2, dest: /etc/keepalived/keepalived.conf, mode: '0644' }
- { src: check_server.sh, dest: /server/scripts/check_server.sh, mode: '0777' }
- { src: proxy_web.conf, dest: /etc/nginx/conf.d/proxy_web.conf, mode: '0644' }
- { src: proxy_params, dest: /etc/nginx/proxy_params, mode: '0644' }
notify: Restart Nginx Server
- name: Systemd Nginx server
systemd:
name: "{{ item }}"
state: started
enabled: yes
with_items:
- nginx
- keepalived 5.handlers触发重启nginx服务
[root@manager lb]# cat handlers/main.yml
- name: Restart Nginx Server
systemd:
name: nginx
state: restarted 6.配置keepalived
[root@manager lb]# cat files/keepalived.conf.j2
global_defs {
router_id {{ ansible_fqdn }}
} vrrp_instance VI_1 {
{% if ansible_fqdn == 'lb01' %}
#lb01的配置如下:
state MASTER
priority 150
{% elif ansible_fqdn == 'lb02' %}
#lb02的配置如下:
state BACKUP
priority 100
{% endif %} interface eth0
virtual_router_id 50
advert_int 1 authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
10.0.0.3
}
} 7.准备对应的j2文件
[root@manager roles]# tree lb/
lb/
├── files
│ └── keepalived.conf.j2
├── handlers
│ └── main.yml
├── tasks
│ └── main.yml
├── templates
│ ├── check_server.sh
│ ├── keepalived.conf.j2
│ ├── nginx.conf.j2
│ ├── proxy_params
│ └── proxy_web.conf

6.Ansible Roles角色实战的更多相关文章

  1. Ansible Roles角色

    Roles小技巧: 1.创建roles目录结构,手动或使用ansible-galaxy init test roles 2.编写roles的功能,也就是tasks. nginx rsyncd memc ...

  2. Ansible--06 ansible roles

    Ansible roles roles不管是Ansible还是saltstack,我在写一键部署的时候,都不可能把所有的步骤全部写入到一个'剧本'文件当中,我们肯定需要把不同的工作模块,拆分开来,解耦 ...

  3. ansible roles实践——安装nginx

    1.创建roles 在/etc/ansible/roles目录下 1.1 手动创建需要的目录 1.2 使用命令创建,用不到的目录可以创建为空目录,但不可以不创建. 创建目录[root@master] ...

  4. ansible roles 目录规范

    我的ansible roles项目的目录结构: (ansible_venv) [root@localhost ansible_home]# tree ansible_playbooks/ ansibl ...

  5. ansible roles 自动化安装

    例:  ansible roles 自动化安装memcached 文件目录结构如下: cat memcached_role.yml - hosts: memcached remote_user: ro ...

  6. Ansible之roles角色

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

  7. ansible roles 介绍和使用

    目录 roles roles 介绍 创建role的步骤 role内个目录中可用的文件 案例 roles roles 介绍 ansible 自1.2版本引入的新特性,用于层次性.结构化地组织playbo ...

  8. ansible roles实践 zookeeper集群部署

    1.下载解压 wget https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/zookeeper-3.4.11/zookeeper-3.4.11. ...

  9. ansible roles实践——安装java

    [root@master] /etc/ansible$ cat roles/java/tasks/main.yml ---- name: unzip jdk unarchive: src=jdk-8u ...

随机推荐

  1. 了解 MongoDB 看这一篇就够了【华为云分享】

    目录 一.简介 二.基本模型 BSON 数据类型 分布式ID 三.操作语法 四.索引 索引特性 索引分类 索引评估.调优 五.集群 分片机制 副本集 六.事务与一致性 一致性 小结 一.简介 Mong ...

  2. 华为担纲建设基础软硬件国家新一代AI开放创新平台

    [摘要] 全栈全场景AI能力爆发! [上海,2019年8月29日] 凭借领先的全栈全场景AI能力华为入选国家新一代人工智能开放创新平台 8月29日,科技部在2019世界人工智能大会宣布,将依托华为建设 ...

  3. luogu P1901 发射站

    题目描述 某地有 N 个能量发射站排成一行,每个发射站 i 都有不相同的高度 Hi,并能向两边(当 然两端的只能向一边)同时发射能量值为 Vi 的能量,并且发出的能量只被两边最近的且比 它高的发射站接 ...

  4. 使用 nginx 实现虚拟主机

    当多个系统需要部署的时候,有系统访问很小,为了节省成本,就需要将多个系统部署到同一台服务器上,怎么在同一台服务器上,完成不同系统的部署和访问,就需要使用虚拟主机实现. 使用端口实现虚拟主机 配置 ng ...

  5. TypeScript - 类型声明、枚举、函数、接口

    目录  可定义的类型  类型声明  枚举  函数  接口 可定义的类型 以下所写的并不代表typescript的数据类型,而是在使用过程中可以用作定义的类型 number : 数值类型: string ...

  6. js原生实现链式动画效果

    // 1. css样式 div { width: 100px; height: 100px; background: olivedrab; position: absolute; left: 0px; ...

  7. 笔记||Python3之字符串格式化输出

    字符串的格式化输出方法一: 常用的字符串格式化符号:%s   ---   用str()函数进行字符串转换 %d   ---   转成有符号十进制数 %f    ---   转成浮点数(小数部分自然截断 ...

  8. 【树莓派】制作启动SD卡

    版权声明:本文为博主原创文章,转载请注明出处. https://www.cnblogs.com/YaoYing/ 下载烧写软件 烧写软件 将下载的压缩文件解压缩并安装到电脑上 下载树莓派镜像 树莓派系 ...

  9. Django大纲

    Django框架 ........ 2.聚合查询 分组 F与Q查询 字段 及其 参数 | 数据库的三大范式 3.orm查询优化 MTV与MVC模型 choice参数 ajax serializers ...

  10. java基础- 你真的了解运算符吗?

    一 前言 学习java运算符的基础是你对数学和计算机原理有一定的要求,如果文章中有些位运算不懂是生么意思,我建议大家去学习一下计算机原理,计算机组成类别的书籍,你也不用深入过多,只要了解计算机大概结构 ...