本文共 1092 字,大约阅读时间需要 3 分钟。
根据官网的说法,自定义modules的文件目录应该是放在/srv/salt/_modules下面,同步到minion的方法有三个:
好吧,先来写个简单的modules试试看,就返回一个当前时间吧:
/srv/salt/_modules/test.py
1 2 3 4 | #!/usr/bin/python import time def date (): return time . time () |
接下来推送到minion:
1 | salt '*' saltutil.sync_modules |
推送完之后运行一下这个modules,方法是:文件名.函数名
恩,感觉还可以,接下来看一下modules如何使用grains和pillar的数据:
/srv/salt/_modules/test.py
1 2 3 4 5 6 7 8 | #!/usr/bin/python import time def date(): return time.time() def get_osfinger(): return __grains__[ 'osfinger' ] def get_cachedir(): return __pillar__[ 'master' ][ 'cachedir' ] |
__grains__ 和 __pillar__ 保存了grains和pillar的数据,我们可以在module中这样来读取,推送到minion之后看看结果:
然后官网还说到一个功能就是调用其它的模块:
/srv/salt/_modules/test.py
1 2 3 4 5 6 7 8 9 10 | #!/usr/bin/python import time def date(): return time.time() def foo(): return __salt__[ 'cmd.run' ]( 'df' ) def get_osfinger(): return __grains__[ 'osfinger' ] def get_cachedir(): return __pillar__[ 'master' ][ 'cachedir' ] |
所有的模块都包含在__salt__字典里面,我试试执行cmd.run "df",看看结果:
这样感觉就可以把一些日常经需要做的工作写成modules,虽然现在还不知道写些什么好。。囧。。。
本文转自运维笔记博客51CTO博客,原文链接http://blog.51cto.com/lihuipeng/1396279如需转载请自行联系原作者
lihuipeng