saltstack管理五之目录结构
目录结构描述:
当我们在学习自动化运维工具时,不论是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-masterrestart
注意:由上面的配置可以看出,配置管理的根目录是/srv/salt
分析:
下面分析配置管理/srv/salt的目录结构:
# cd /srv/salt
# tree
.
├── top.sls
└── web
├── httpd.sls
├── init.sls
└── php
└── conf.sls
1、 入口文件top.sls:
在/srv/salt/目录下面有个入口文件top.sls,当master服务启动后,master进程会首先去读取这个入口文件
# 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目录:
# pwd
/srv/salt
# mkdir web
# cd 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文件)
# pwd
/srv/salt/web
# ls
httpd.slsinit.sls php
如上:我们需要创建一个httpd.sls文件,mkdir一个php目录
例子1:
# tree
.
├── web
│?? └── httpd
│?? └── httpd.sls
├── top.sls
# cat top.sls
base:
'*':
- web.httpd.httpd
首先读取top.sls文件,去找配置根目录下web目录下httpd目录下的httpd.sls文件,
(没有httpd.sls文件,再去找配置根目录下web目录下httpd目录下httpd目录下的init.sls文件)
都没有则报错
例子2:
# tree
.
├── top.sls
└── web
├── httpd
│?? └── httpd.sls
└── init.sls
# cat top.sls
base:
'*':
- web
# cat web/init.sls
include:
- web.httpd.httpd
读取top.sls文件,先去找配置根目录下的web.sls文件;
若没有web.sls文件,则再去找配置根目录下web目录下的init.sls文件,
若init.sls文件不存在则报错
例子3:
# tree
.
├── db
│?? └── db
│?? └── db.sls
├── top.sls
└── web
├── httpd
│?? └── httpd.sls
└── init.sls
# cat top.sls
base:
'*':
- web
# cat web/init.sls
include:
- web.httpd.httpd
- db.db.db
例子4:
# tree
.
├── db
│?? └── db
│?? └── db.sls
├── top.sls
└── web
├── httpd
│?? └── httpd.sls
└── init.sls
# cat top.sls
base:
'*':
- web
# cat web/init.sls
include:
- web.httpd.httpd
# 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文件的内容:
# 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
页:
[1]