ningleesherry 发表于 2018-8-1 08:15:53

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]
查看完整版本: saltstack管理五之目录结构