一、简介

Ansible1.2版本后引入的新特性,用于层次性、结构化地组织playbook。roles能够根据层次型结构自动装载变量文件、tasks以及handlers等。要使用roles只需要在playbook中使用include指令即可。简单来讲,roles就是通过分别将变量、文件、任务、模板及处理器放置于单独的目录中,并可以便捷地include它们的一种机制。角色一般用于基于主机构建服务的场景中,但也可以是用于构建守护进程等场景中

二、roles目录结构

官方推荐在/etc/ansible/roles目录下使用roles,但不是必须的,roles目录可以自行创建

     tasks-包含角色要执行的任务的主要列表,至少应该有main.yml文件,有其他的yml文件通过include进行包含
     handlers-包含处理程序(notify触发的任务),该角色甚至该角色之外的任何地方都可以使用这些处理程序。至少应该有main.yml文件
     defaults-角色的默认变量,至少应该有main.yml文件
     vars-角色的其他变量,至少应该有main.yml文件
     files-包含可以通过此角色部署的文件。
     templates-包含可以通过此角色部署的模板。
     meta-为此角色定义一些元数据,至少应该有main.yml文件

以部署grafana+influxdb+telegraf为例
目录结构如下:

在项目目录中,剧本与roles目录平级,roles目录下包含各角色目录,各角色目录中包含使用到的files,handlers,tasks,templates,vars;对于不使用的meta和defaults目录,最好排除。

三、roles示例

以部署grafana+influxdb+telegraf为例

3.1、需求

在node2上部署三件套,在node3上部署influxdb,配置文件中的有些参数使用变量,配置文件使用模板,更改配置文件后重启服务

3.2、部署剧本 deploy.yml

---
 - hosts: node2
   remote_user: root
   roles:
   - grafana
   - influxdb
   - telegraf
- hosts: node3
   remote_user: root
   roles:
   - influxdb

3.3、角色以grafana为例

roles/grafana/tasks/main.yml文件

---
- name: "copy grafana to destination server"
  copy:
    src: grafana-6.3.0-1.x86_64.rpm
    dest: /tmp/
- name: "Install the grafana rpm package locally"
  yum:
    name: /tmp/grafana-6.3.0-1.x86_64.rpm
    state: present
- name: "template the grafana.ini"
  template:
    src: grafana.ini.j2
    dest: /etc/grafana/grafana.ini
  notify: restart grafana

- name: "enable grafana"
  systemd:
    name: grafana-server
    state: restarted
    daemon_reload: yes
    enabled: yes

roles/grafana/templates/grafana.ini.j2模板配置文件

# The http port  to use
http_port = {{ http_port }}

roles/grafana/vars/main.yml 文件

http_port: 8000

roles/grafana/handlers/main.yml文件

- name: restart grafana
  systemd:
    name: grafana-server
    state: restarted
    daemon_reload: yes

3.4、hosts文件

/etc/ansible/hosts 
[node2]
192.168.143.131
[node3]
192.168.143.132 

3.5、执行deploy.yml

ansible-playbook deploy.yml

参考:马哥ansible视频