一、roles文件存放位置
可以在ansible.cfg配置文件中找到,默认路径如下:
也可以在ansible.cfg文件中自定义修改
二、下面以/usr/share/ansible目录来讲解
ansible的目录结构如下以安装httpd为示例:
[root@localhost share]# tree ansible/
ansible/
├── http_playbook.yml # 和roles平级,来调用对应的剧本
├── plugins # 默认自带的插件目录
└── roles # roles存放那个目录
├── app # 安装app的剧本
├── httpd # 安装htppd的剧本
│ ├── files #file模块用到的文件存放的目录, tasks中也可以使用绝对路径来调用其他位置的文件
│ │ └── 1for.txt
│ ├── handlers # handlers任务,和notify配合使用, 这里需要用main.yml来做handlers任务的总调用,可以在该目录下定义其他yml,但是必须加入main.yml中来调用
│ │ └── main.yml # handlers任务的总入口
│ ├── tasks # taks目录,该目录下可以定义很多yml文件来执行操作,但是必须main.yml作为总调用入口,相当于把原本写在一个playbook中的任务分开执行,增加文件的复用性和灵活性
│ │ ├── cp_conf.yml
│ │ ├── group.yml
│ │ ├── main.yml
│ │ ├── service.yml
│ │ ├── teml2.yml
│ │ ├── teml.yml
│ │ ├── user.yml
│ │ └── yum.yml
│ ├── templates # task中用到的木板文件默认都存放在该目录下以便调用
│ │ ├── 2for.txt
│ │ └── httpd.conf
│ └── vars # task中的参数全部定在该目录下,并且以main.yml为入口
│ └── main.yml
└── nginx # 安装nginx软件的剧本
三、关键文件展示
总入口文件,只是编写内容比传统playbook少,只需要调用roles下面对应的剧本即可:
tasks入口文件,tasks目录下的独立任务只是把原来的playbook中的tasks独立拆分出来而以,还是需要经由main.yml文件调用:
handlers及vars入口文件展示。同样这些文件都可以和task目录一样来编写,确保使用main.yml文件做主的入口调用即可:
四、关于剧本roles和playbook的区别
个人理解:
playbook是在一个yml文件中完成了所有的事情,当一个任务或几个任务很简单就能实现的话就比较方便,类是于一个shell脚本搞定所有事情,缺点就是复用性、可移植性不高
roles就是把playbook里面的任务全部拆解出来,模块化,构成一个框架。这样在较大工程环境下灵活性很好,并且维护起来比较方便。类似于用很多shell脚本创建一个大工程,每个shell脚本都有自己独立的功能。