目录结构




描述:

当我们在学习自动化运维工具时,不论是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