这一篇总结一下mine函数的用法,mine函数是个啥呢?和咱们linux里面的crontab有点类似。

有了它,咱们执行任务收集信息,就不用守着屏幕了。

mine其实,是从minions上面收集信息,然后保存在master上面,

存在这个地方的,请看

root@salt-master:~# ls /var/cache/salt/master/minions/salt-minion/mine.p 
/var/cache/salt/master/minions/salt-minion/mine.p
root@salt-master:~#

不过它保存的这些数据都是最新的数据。

这个是为啥呢?因为mine是周期执行的,默认是60分钟一次。而新产生的最新数据会把老数据覆盖掉,所以我们是看不到老数据的,如果想要看历史数据的话,我们可能就要用returner了。

下面看看mine怎么用的吧

楼主总结了一下,大概一共有两种方法吧,超过的话,就是楼主还没看到了。

其中有一种定义在minion的配置文件里面

显而易见,定义在minion里面的mine只对当前的minion起作用

另外一种方法是,通过在命令行,用mine模块的几个函数来维护的。。。这种方法胜在灵活,但是当minions重启之后,我们通过这种方式产生的mine函数都会被清空,不能用了。

好,咱们先看看第一种方法吧,定义在minion的配置文集里面。

好,先把需要的内容放进/etc/salt/minion.d/mine.conf里面

root@salt-master:/srv/pillar# salt '*'   cmd.exec_code  bash 'echo -e "mine_functions:\n  \
>disk.percent:\n    - /home\nmine_interval: 1" >>/etc/salt/minion.d/mine.conf '
salt-minion:

查看一下,基本实现就是这样的。以mine_functions打头,告诉人家这是一系列的mine函数。

下面就是一个个的函数,后面可以带参数 /home就是disk.percent这个函数的参数。

mine_interval: 1是设定,mine函数执行周期,单位是分钟,这里设置的是1分钟执行一次。

root@salt-master:/srv/pillar# salt '*' cmd.run 'cat /etc/salt/minion.d/mine.conf'
salt-minion:
    mine_functions:
      disk.percent:
        - /home
    mine_interval: 1
root@salt-master:/srv/pillar#

OK,重启下minion

root@salt-master:/srv/pillar# salt '*' service.restart   salt-minion
salt-minion:
    True

在master端。get一下,这是查看mine数据的方法。后面跟上mine函数的名字就OK了

root@salt-master:/srv/pillar# salt '*' mine.get '*' disk.percent
salt-minion:
    ----------
    salt-minion:
        2%

注意:第一个'*',大伙应该都知道是干啥的。第二个'*',和第一个差不多再进一步匹配一次。就是说第一个匹配,是在所有的minion匹配一次,第二次是在所有的定义了disk.percent mine函数的minions再按照规则匹配一次。

下面咱们举个例子,安装grains匹配一下。看到了吧

root@salt-master:/srv/pillar# salt '*' mine.get 'os:Debian' disk.percent grain
salt-minion:
    ----------
    salt-minion:
        2%


OK,第一种方式写完了,现在总结下第二种方式,命令行。

主要是由这几个命令管理的。

root@salt-master:~# salt  '*' -d mine | egrep -v "(^$|^ )"
mine.delete:
mine.flush:
mine.get:
mine.send:
mine.update:
root@salt-master:~#

发送mine函数到minine上

root@salt-master:~# salt '*' mine.send  cp.list_minion

get一下。注意,上面我们发过去的那个函数,只执行一次,不是周期性执行的,所以我们每次

get的数据,都是一样的

root@salt-master:~# salt '*' mine.get  '*' cp.list_minion
salt-minion:
    ----------
    salt-minion:
        - /var/cache/salt/minion/extmods/grains/mine.sls
        - /var/cache/salt/minion/extmods/returners/mysql_return.py
        - /var/cache/salt/minion/extmods/returners/mysql_return.pyc
        - /var/cache/salt/minion/files/base/_grains/mine.sls
        - /var/cache/salt/minion/files/base/_returners/mysql_return.py
        - /var/cache/salt/minion/files/base/_returners/mysql_return.py1
        - /var/cache/salt/minion/module_refresh
        - /var/cache/salt/minion/proc/20140625150737002594
root@salt-master:~#

清空cache

root@salt-master:~# salt '*' mine.flush
salt-minion:
    True
root@salt-master:~# ls /var/cache/salt/master/minions/salt-minion/mine.p 
ls: cannot access /var/cache/salt/master/minions/salt-minion/mine.p: No such file or directory
root@salt-master:~#

mine.update的意思,是立即刷新那些周期性的mine函数。 比如说,一个mine函数每60分钟执行一次,现在离上次执行刚刚过了5分钟,我现在想立马执行,看看最新的结果,我们用这个东西就OK了