【puppet 模块导读】
在puppet运维管理中,很多同学安装配置好puppet后,就急不可待的写puppet模块,我个人还是建议大家先熟悉puppet各种资源管理后,再写puppet模块。假如你已经看完了puppet管理各种资源后,并且熟悉了模块和类的操作,现在你可以写自己的第一个puppet模块,在使用模块之前我们要知道,puppet的模块存放的路径是在哪里?如何引用模块呢?接下来sky就为大家写个简单的puppet模块供大家参考。
【puppet 模块基础】
puppet模块可以导入,复用都很方便,在这里sky先回答下之前的两个回答。
1.查看puppet 模块路径,可以使用如下命令:
puppetmasterd –configprint modulepath /etc/puppet/modules:/usr/share/puppet/modules ##可以看到这两个目录是puppet 模块默认所在的目录。
2.要引用 puppet模块,如果模块所在上面的两个默认的路径可以使用:
import “模块名”
如果不在,比如我在/data/modules,那么有两种解决方法:
1.是修改puppet.conf文件,添加目录到modulepath.举例 :
modulepath = /data/modules:/etlc/puppet/modules
2.是在引用的是时候用绝对路径。
import "/data/modules/模块名"
了解完puppet 模块基础后,接下来sky就为大家写个简单模块示例:
【puppet 模块实例】
现在请跟sky一起来写简单的模块吧:
cd /etc/puppet/modules mkdir -p test/{manifests,files,templates}
这三个目录说明:files目录是用来存放同步远程客户端的文件或者文件夹,manifests目录下放.pp文件,而且必须要有init.pp,templates是存放的puppet模板文件,是以.erb结尾的
建立init.pp文件
cat test/manifests/init.pp class test::test { file { "/tmp/sky": owner => root, group => root, ensure => present, content => "www.mysqlops.com test by sky", mode => 644, } }
在/etc/puppet/manifests/site.pp里添加node "web01.test.com" { include test::test }
注:不建议这样操作,实际生产中,我会在site.pp里添加 import “nodes.pp”,然后在nodes.pp里添加上面的内容。
这样我们就建立了我们第一个puppet 模块,sky在到客户端web01.test.com上运行puppet查看结果:
[root@web01 ~]# puppet agent --server puppet --test info: Caching catalog for web01.fminutes.com info: Applying configuration version '1319738837' notice: /Stage[main]/Test::Test/File[/tmp/sky]/ensure: created notice: Finished catalog run in 0.04 seconds [root@web01 ~]# cat /tmp/sky www.mysqlops.com test by sky
再次验证,可以看到已经成功运行,已经达到预期的效果。在/tmp/目录下生成了sky这个文件,有个问题,不知道大家注意到没有,sky这里并没有import "test"模块,而直接使用了include test::test类。有兴趣的同学可以试试,再看下效果,
【puppet模块总结】
模块是由类构成,但最原始的都是代码,只要我们平时在puppet运维过程中,经常使用puppet管理常用资源等,还是要不断的摸索的,不断总结经验,puppet运维过程中,如有不清楚的问题,最好通过google,或者去puppetlabs实验上,去查看手册。本次puppet模块示例就到此结束。puppet有更多功能期待大家的发现。