Ansible--Templates 模块 Tags模块 Roles模块

一 Templates 模块

①Jinja是基于Python的模板引擎。Template类是Jinja的一个重要组件,可看作一个编译过的模

板文件,用来产生目标文本,传递Python的变量给模板去替换模板中的标记。

②在配置文件中,会有一些数据(如:ip 地址、主机名、端口、用户、页面路径等)会动态的改

变,需要使用变量来表示;

③template 模块就是将变量和动态文件结合起来,最终生成一个配置文件(需要动态改变)。文件

使用 jinjia2 模块语言来编写,结尾(后缀)一定是 j2(xxx.j2)。

实验:通过 playbook 安装 apache

1 先准备一个以 .j2 为后缀的 template 模板文件,设置引用的变量

cp /etc/httpd/conf/httpd.conf /opt/httpd.conf.j2

vim /opt/httpd.conf.j2
Listen {{http_port}}				#42行,修改
ServerName {{server_name}}			#95行,修改
DocumentRoot "{{root_dir}}"          #119行,修改  总控制端,可以管理被控制点

[root@11-6 opt]# vim /opt/httpd.conf.j2

2 修改主机清单文件,使用主机变量定义一个变量名相同,而值不同的变量

vim /etc/ansible/hosts

3 编写 playbook

vim cs_cs_apache.yaml

---
- name: install httpd
  hosts: all
  remote_user: root
  vars:
    - package: httpd
    - service: httpd
  tasks:
    - name: install httpd package
      yum: name={{package}} state=latest
    - name: copy confg file
      template: src=/opt/httpd.conf.j2 dest=/etc/httpd/conf/httpd.conf     
      notify:
        - restart httpd
    - name: start httpd server
      service: name={{service}} enabled=true state=started
  handlers:
    - name: restart httpd
      service: name={{service}} state=restarted

4 被管理点添加域名

5 被管理者导入文本:

6 管理者与被管理者达成共识:

7 检测一下:

systemctl restart httpd

8 另一种检测方法:

[root@11-6 opt]# vim /etc/ansible/hosts

[root@11-6 opt]# vim /opt/httpd.conf.j2

二 tags 模块

例如:安装tomcat 必需现有jdk,就可以用这种方式部署

可以在一个playbook中为某个或某些任务定义"标签",在执行此playbook时通过ansible-playbook

命令使用--tags选项能实现仅运行指定的tasks。

playbook还提供了一个特殊的tags为always。作用就是当使用always当tags的task时,无论执行哪

一个tags时,定义有always的tags都会执行。

  • 标签调用哪一个就执行哪一个
  • 如果指定的标签是always,不管指定不指定,都执行
  • 执行顺序从上往下

注:标记那个标签执行那个操作

---
- name: ceshi tags
  hosts: mcbweb01
  remote_user: root
  tasks:
    - name: copy hosts file
      copy: src=/etc/hosts dest=/opt/hosts
      tags:
        - JOB
    - name: touch file
      file: path=/opt/kangkang state=touch

[root@11-6 opt]# ansible-playbook cs_webhost.yaml --tags="JOB"

检测:

若有always都会执行操作

执行一下

[root@11-6 opt]# ansible-playbook cs_webhost.yaml --tags="K"

always

---
- name:  or tags
  hosts: mcbweb01
  remote_user: root
  tasks:
    - name: copy hosts file
      copy: src=/etc/hosts dest=/opt/hosts
      tags:
        - K
    - name: touch file
      file: path=/opt/ab state=touch
        - always
    - name:  create dir     
      file: path=/opt/F state=directory
      tags:
        - F

检测一下:

三 Roles 模块

Ansible为了层次化、结构化地组织Playbook,使用了角色(roles),roles可以根据层次型结构自

动装载变量文件、task以及handlers等。简单来讲,roles就是通过分别将变量、文件、任务、模块

及处理器放置于单独的目录中,并可以便捷地include它们。roles一般用于基于主机构建服务的场

景中,但也可以用于构建守护进程等场景中。

//roles 的目录结构:

cd /etc/ansible/

tree roles/

roles/

1 roles 内各目录含义解释

●files
用来存放由 copy 模块或 script 模块调用的文件。

●templates
用来存放 jinjia2 模板,template 模块会自动在此目录中寻找 jinjia2 模板文件。

●tasks
此目录应当包含一个 main.yml 文件,用于定义此角色的任务列表,此文件可以使用 include 包含其它的位于此目录的 task 文件。

●handlers
此目录应当包含一个 main.yml 文件,用于定义此角色中触发条件时执行的动作。

●vars
此目录应当包含一个 main.yml 文件,用于定义此角色用到的变量。

●defaults
此目录应当包含一个 main.yml 文件,用于为当前角色设定默认变量。

●meta
此目录应当包含一个 main.yml 文件,用于定义此角色的特殊设定及其依赖关系。

2 在一个 playbook 中使用 roles 的步骤:

(1)创建以 roles 命名的目录

mkdir /etc/ansible/roles/ -p    #yum装完ansible默认就有

(2)创建全局变量目录(可选)

mkdir /etc/ansible/group_vars/ -p

touch /etc/ansible/group_vars/all     #文件名自己定义,引用的时候注意

(3)在 roles 目录中分别创建以各角色名称命令的目录,如 httpd、mysql

mkdir /etc/ansible/roles/httpd

mkdir /etc/ansible/roles/mysql

(4)在每个角色命令的目录中分别创建files、handlers、tasks、templates、meta、defaults和

vars目录,用不到的目录可以创建为空目录,也可以不创建

mkdir /etc/ansible/roles/httpd/{files,templates,tasks,handlers,vars,defaults,meta}

mkdir /etc/ansible/roles/mysql/{files,templates,tasks,handlers,vars,defaults,meta}

(5)在每个角色的 handlers、tasks、meta、defaults、vars 目录下创建 main.yml 文件,千万不

能自定义文件名

touch /etc/ansible/roles/httpd/{defaults,vars,tasks,meta,handlers}/main.yml

touch /etc/ansible/roles/mysql/{defaults,vars,tasks,meta,handlers}/main.yml

(6)修改 site.yml 文件,针对不同主机去调用不同的角色

vim /etc/ansible/mcb.yml

---
- hosts: mcbweb01
  remote_user: root
  roles:
     - httpd
- hosts: mcb02
  remote_user: root
  roles:
     - mysql
~               

(7)运行 ansible-playbook

cd /etc/ansible

ansible-playbook mcb.yml

示例:

mkdir /etc/ansible/roles/httpd/{files,templates,tasks,handlers,vars,defaults,meta} -p
mkdir /etc/ansible/roles/mysql/{files,templates,tasks,handlers,vars,defaults,meta} -p
mkdir /etc/ansible/roles/php/{files,templates,tasks,handlers,vars,defaults,meta} -p

touch /etc/ansible/roles/httpd/{defaults,vars,tasks,meta,handlers}/main.yml
touch /etc/ansible/roles/mysql/{defaults,vars,tasks,meta,handlers}/main.yml
touch /etc/ansible/roles/php/{defaults,vars,tasks,meta,handlers}/main.yml

[root@11-6 opt]# tree /etc/ansible/roles/
/etc/ansible/roles/
├── httpd
│   ├── defaults
│   │   └── main.yml
│   ├── files
│   ├── handlers
│   │   └── main.yml
│   ├── meta
│   │   └── main.yml
│   ├── tasks
│   │   └── main.yml
│   ├── templates
│   └── vars
│       └── main.yml
├── mysql
│   ├── defaults
│   │   └── main.yml
│   ├── files
│   ├── handlers
│   │   └── main.yml
│   ├── meta
│   │   └── main.yml
│   ├── tasks
│   │   └── main.yml
│   ├── templates
│   └── vars
│       └── main.yml
└── php
    ├── defaults
    │   └── main.yml
    ├── files
    ├── handlers
    │   └── main.yml
    ├── meta
    │   └── main.yml
    ├── tasks
    │   └── main.yml
    ├── templates
    └── vars
        └── main.yml

24 directories, 15 files

四 青春版的LNMP

1 编写httpd模块

写一个简单的tasks/main.yml

vim /etc/ansible/roles/httpd/tasks/main.yml

相关推荐
PcVue China2 小时前
PcVue + SQL Grid : 释放数据的无限潜力
大数据·服务器·数据库·sql·科技·安全·oracle
舞动CPU4 小时前
linux c/c++最高效的计时方法
linux·运维·服务器
钰@5 小时前
小程序开发者工具的network选项卡中有某域名的接口请求,但是在charles中抓不到该接口
运维·服务器·小程序
wanhengwangluo5 小时前
云服务器和物理服务器的区别有哪些?
运维·服务器
扣得君7 小时前
C++20 Coroutine Echo Server
运维·服务器·c++20
keep__go7 小时前
Linux 批量配置互信
linux·运维·服务器·数据库·shell
矛取矛求7 小时前
Linux中给普通账户一次性提权
linux·运维·服务器
jieshenai8 小时前
使用VSCode远程连接服务器并解决Neo4j无法登陆问题
服务器·vscode·neo4j
渗透测试老鸟-九青8 小时前
通过投毒Bingbot索引挖掘必应中的存储型XSS
服务器·前端·javascript·安全·web安全·缓存·xss
Gentle5868 小时前
labview连接sql server数据库
服务器·数据库·labview