Ansible中的角色使用

ansible roles

#ansible 角色简介#
* Ansible roles 是为了层次化,结构化的组织Playbook
* roles就是通过分别将变量、文件、任务、模块及处理器放置于单独的目录中,并可以便捷地include它们
* roles一般用于基于主机构建服务的场景中,在企业复杂业务场景中应用的频率很高
* 以特定的层级目录结构进行组织的tasks、variables、handlers、templates、files等;相当于函数的调用把各个功能切割成片段来执行。

roles目录结构

files 存放copy或script等模块调用的函数
tasks 定义各种task,要有main.yml,其他文件include包含调用
handlers 定义各种handlers,要有main.yml,其他文件include包含调用
vars 定义variables,要有main.yml,其他文件include包含调用
templates 存储由template模块调用的模板文本
meta 定义当前角色的特殊设定及其依赖关系,要有main.yml的文件
defaults 要有main.yml的文件,用于设定默认变量
tests 用于测试角色

role存放的路径在配置文件ansible.cfg中定义

roles_path = path/roles  (默认目录:/etc/ansible/roles)

创建目录结构

$ ansible-galaxy init apache
$ ansible-galaxy list 

 

 

playbook中使用roles

playbook中使用roles:
---
- hosts: server2
  roles:
    - role: role1
    - role: role2
      var1: value1		##此处变量会覆盖roles中的定义变量

控制任务执行顺序

---
- hosts: server2
  roles:
    - role: role1	##角色任务
  pre_tasks:		##角色执行前执行的play
    - tasks1
  tasks:		##普通任务
    - tasks2
  post_tasks:		##在角色和普通任务执行完毕后执行的play
    - tasks3
  handlers:

ansible—galaxy命令工具

* Ansible Galaxy 是一个免费共享和下载 Ansible 角色的网站,可以帮助我们更好的定义和学习roles。
* ansible-galaxy命令默认与https://galaxy.ansible.com网站API通信,可以查找、下载各种社区开发的 Ansible 角色
* ansible-galaxy在 Ansible 1.4.2 就已经被包含了
* 在galaxy.ansible.com网站查询roles

安装选择的角色

#install https://galaxy.ansible.com roles
$ansible-galaxy install geerlingguy.nginx

install local roles

$ vim install_apache_role.yml
---
- src: file:///mnt/apache.tar.gz
  name: apache

$ ansible-galaxy  install -r install_apache_role.yml

练习:

使用roles配置DNSDHCP(DDNS) 花生壳

vim ~/ddns.yml
---
- name: ddns
  hosts: all
  roles:
    - role: ~/ansible/dns
...

tasks

vim ~/ansible/dns/tasks/main.yml

---
- name: install dhcp-server and bind
  dnf:
    name: "{
   
   {item}}"
    state: present
  loop:
    "{
   
   {SOFTWARE}}"
  notify: set firewalld

- name: create dhcpd.conf and named.conf
  template:
      src: "{
   
   {item.src}}"
      dest: "{
   
   {item.dest}}"
      group: "{
   
   {item.group}}"
  loop:
    "{
   
   {FILES}}"
  notify: restart server

 vars

---
SOFTWARE:
  - bind
  - dhcp-server

FILES:
  - src: named.conf.j2
    dest: /etc/named.conf
    group: named
  - src: westos.key.j2
    dest: /etc/westos.key
    group: named
  - src: westos.com.zone.j2
    dest: /var/named/westos.com.zone
    group: named
  - src: named.rfc1912.zones.j2
    dest: /etc/name.rfc1912.zones.zones
    group: named
  - src: dhcpd.conf.j2
    dest: /etc/dhcp/dhcpd.conf
    group: root

 templates

扫描二维码关注公众号,回复: 12569230 查看本文章

handlers

---
- name: restart server
  service:
    name: "{
   
   {item}}"
    state: restarted
    enabled: yes
  loop:
    - named
    - dhcpd
- name: set firewalld
  firewalld:
    service: "{
   
   {item}}"
    permanent: yes
    state: enabled
    immediate: yes
  loop:
    - dns
    - dhcp

 

猜你喜欢

转载自blog.csdn.net/Sun__s/article/details/111831931