设为首页 收藏本站
查看: 1046|回复: 0

[经验分享] saltstack(十)mine函数

[复制链接]

尚未签到

发表于 2018-8-1 10:35:32 | 显示全部楼层 |阅读模式
  这一篇总结一下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了

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-544626-1-1.html 上篇帖子: saltstack 资源管理(随记) 下篇帖子: saltstack(十一)runners
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表