目录结构
描述:
当我们在学习自动化运维工具时,不论是puppet还是saltstack,要想熟练使用,必须先弄清楚他们的目录结构,总体来说:puppet和salt的目录结构是很相似的
第一部分:
file_roots配置管理的目录结构:
前提:
使用配置管理的目录结构,首先要在配置文件里配置:
vi /etc/salt/master
找到file_roots,大约在31行
添加:
file_roots:
base:
- /srv/salt
mkdir -p /srv/salt
/etc/init.d/salt-master restart
注意:由上面的配置可以看出,配置管理的根目录是/srv/salt
分析:
下面分析配置管理/srv/salt的目录结构: [root@scj salt]# cd /srv/salt [root@scj salt]# tree . ├── top.sls └── web ├── httpd.sls ├── init.sls └── php └── conf.sls
1、 入口文件top.sls:
在/srv/salt/目录下面有个入口文件top.sls,当master服务启动后,master进程会首先去读取这个入口文件
[root@scj salt]# cat top.sls
base:
'*':
- web
第一行:是top.sls文件的固定写法
第二行:指定要管理的minion机,*代表所有的minion机(一定要用引号引起来),若只管理一台minion机,则可以指定其ip,如:'192.168.186.129'
第三行:指定要读取的模板,定义一个web模板(即在/srv/salt/目录下创建一个web目录),可以定义多个模板目录
注意:第一行和第二行后面有冒号
第二行指定要管理的minion机,可以通过正则,grain模块或分组名来进行匹配,如下:
通过正则进行匹配:
base:
'*':
- web
通过分组进行匹配:必须要有 - match: nodegroup
base:
'BJwebgroup':
- match: nodegroup
- web
通过grain模块匹配:必须要有- match: grain
base:
'os:CentOS':
- match: grain
- web
2、 模块目录:
在入口文件top.sls定义了一个web模块目录,因此我们要创建一个web目录:
[root@scj salt]# pwd
/srv/salt
[root@scj salt]# mkdir web
[root@scj salt]# cd web/
[root@scj web]# vi init.sls
include:
- web.httpd
- web.php.conf
注意:init.sls文件可以简单的看作是模块的入口文件
在调用模块时会首先读取这个init.sls文件,因此一定要创建这个init.sls文件
第一行:固定用法,指:调用下面定义的文件
第二行:调用web模块目录下面的httpd.sls文件(因此在web目录下有个httpd.sls文件)
第三行:调用web模块目录下php目录下面的conf.sls文件(因此在web目录下有个php目录,在php目录下有个conf.sls文件)
[root@scj web]# pwd
/srv/salt/web
[root@scj web]# ls
httpd.sls init.sls php
如上:我们需要创建一个httpd.sls文件,mkdir一个php目录
例子1: [root@dbm133 salt]# tree . ├── web │?? └── httpd │?? └── httpd.sls ├── top.sls [root@dbm133 salt]# cat top.sls base: '*': - web.httpd.httpd 首先读取top.sls文件,去找配置根目录下web目录下httpd目录下的httpd.sls文件, (没有httpd.sls文件,再去找配置根目录下web目录下httpd目录下httpd目录下的init.sls文件) 都没有则报错 例子2: [root@dbm133 salt]# tree . ├── top.sls └── web ├── httpd │?? └── httpd.sls └── init.sls [root@dbm133 salt]# cat top.sls base: '*': - web [root@dbm133 salt]# cat web/init.sls include: - web.httpd.httpd 读取top.sls文件,先去找配置根目录下的web.sls文件; 若没有web.sls文件,则再去找配置根目录下web目录下的init.sls文件, 若init.sls文件不存在则报错 例子3: [root@dbm133 salt]# tree . ├── db │?? └── db │?? └── db.sls ├── top.sls └── web ├── httpd │?? └── httpd.sls └── init.sls [root@dbm133 salt]# cat top.sls base: '*': - web [root@dbm133 salt]# cat web/init.sls include: - web.httpd.httpd - db.db.db 例子4: [root@dbm133 salt]# tree . ├── db │?? └── db │?? └── db.sls ├── top.sls └── web ├── httpd │?? └── httpd.sls └── init.sls [root@dbm133 salt]# cat top.sls base: '*': - web [root@dbm133 salt]# cat web/init.sls include: - web.httpd.httpd [root@dbm133 salt]# cat web/httpd/httpd.sls include: - db.db.db /tmp/scj/file3: file: - managed 通过入口文件top.sls文件,init.sls文件和include关键字,把所有的.sls文件结合了起来; 注意文件的读取顺序
第二部分:
pillar_roots的目录结构:
pillar的目录结构与上面state的file_roots的目录结构一模一样
3、 简单看下几个.sls文件的内容:
[root@scj web]# cat httpd.sls httpd: pkg: - installed httpd: service: - running - reload: True - enable: True - watch: - file: /tmp/salt/httpd.conf - require: - pkg: httpd /tmp/salt/httpd.conf: file: - managed - source: salt://web/files/httpd.conf - require: - pkg: httpd