实例一、文件分发
描述:通过puppet服务端可以向被管理机(客户端)上推送文件,方法是使用file类型的source属性
第一步:#vi /etc/puppet/fileserver.conf
1 [files]
2 path /opt/ # 设置文件推送到目录
3 allow 192.168.133.0/24 # 设置准许连接到服务端的主机地址
第二步:vi /etc/puppet/manifests/site.pp
1 file
2 { "/opt/mysql-5.1.49-linux-i686-icc-glibc23.tar.gz":
3 source => "puppet://$puppetserver/files/mysql-5.1.49-linux-i686-icc-glibc23.tar.gz",
4 }
5 //设置服务器上/opt目录下的mysql-5.1.49-linux-i686-icc-glibc23.tar.gz为被传送文件
6 //此处“$puppetserver”是Puppet Server端的名称,即hostname,在hosts文件里指定,生产环境下用内部的DNS上作解析
第三步:
在客户端执行更新命令
1 #puppetd --test --server server.puppet
实例二、修改文件属性
描述:把/tmp/dd142/ puppet-2.6.13.tar.gz文件的权限改为puppet用户,并设置权限为666。
第一步:编辑服务端的site.pp
vi /etc/puppet/manifests/site.pp
------------------------------------------------------
1 file
2 { "/tmp/dd142/puppet-2.6.13.tar.gz":
3 owner => "puppet",
4 group => "puppet",
5 mode => 666,
6 }
第二步:在客户端执行命令
1 #puppetd --test --server server.puppet
实例三、执行SHELL命令或shell脚本
描述:通过puppet分发执行shell脚本,在客户端的opt目录下新建一目录shelldir。
第一步:编辑服务端的site.pp
1 vi /etc/puppet/manifests/site.pp
2 ---------------------------------------------
3 exec { "exec-mkdir":
4 cwd => "/opt", //切换到命令行运行时目录
5 command => "sh /opt/lgh.sh",
6 user => "root",
7 path => "/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin",
8 }
第二步:在客户端编辑上一步command路径中指定的shell脚本,例如
1 vi /opt/lgh.sh
2 ---------------------------------------------
3 #!/bin/bash
4 mkdir /opt/shelldir
第三步:在客户端执行命令
1 # puppetd --test --server server.puppet
在/opt目录下查看shelldir目录有没有建立。
实例四、cron计划任务
描述:接上面的shell程序实例,在17:30执行/opt/lgh.sh。
第一步:编辑服务端的site.pp
1 vi /etc/puppet/manifests/site.pp
2 ---------------------------------------------
3 cron { "cron-shell": #title部分,可用来作为注释。
4 command => "sh /opt/lgh.sh" #要执行的命令
5 user => "root", #添加到root用户下的crontab中
6 minute => "30", #即第一个星号
7 hour => "17" #即第二个星号
8 }
第二步:在客户端执行命令
puppetd --test --server server.puppet
然后在客户端使用#crontab -l查看效果
1 [iyunv@client ~]# crontab -l
2 # HEADER: This file was autogenerated at Mon Nov 04 16:56:25 +0800 2013 by puppet.
3 # HEADER: While it can still be managed manually, it is definitely not recommended.
4 # HEADER: Note particularly that the comments starting with 'Puppet Name' should
5 # HEADER: not be deleted, as doing so could cause duplicate cron jobs.
6 # Puppet Name: cron-shell
7 30 17 * * * sh /opt/lgh.sh
实例五、服务检查及状态修改
描述:可以通过puppet对一些服务进行检查。puppet是通过service命令操作的。所以,只能针对在/etc/init.d/目录下的服务
实例:把客户端的防火墙起来
第一步:编辑服务端的site.pp
vi /etc/puppet/manifests/site.pp
----------------------------------------------
service
{ iptables:
ensure => "running",
}
第二步:在客户端执行命令
puppetd --test --server server.puppet
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com