自动化运维管理平台-Puppet资源管理
当我们配置完毕puppet相关信息时,我们需要更近一步来部署puppet真正应用,那puppet怎么使用呢?希望帮助到初学的朋友,一起交流和学习,欢迎大家分享!Puppet常用资源:
常用的资源主要有以下几个:
file:主要负责管理文件
package:软件包的安装管理
service:系统服务的管理
cron:配置自动任务计划
exec:远程执行运行命令
更多资源详细资料,可参见:http://puppet.wikidot.com
写一个默认配置:vi/etc/puppet/manifests/site.pp
一、File资源:
file {
"/tmp/test.txt":
content => "hello";
}
意思是在/tmp新建一个test.text文件,文件内容为hello。
二、Package资源:
package {
["screen","ntp"]:
ensure => "installed";
"pppoe":
ensure => "absent";
}
定义的意思是yum install screen 和ntp服务,并且卸载pppoe安装包。
三、Service资源:
service {
"sshd":
ensure => running;
"nfs":
ensure => stopped;
}
意思是定义启动sshd服务,停止nfs服务。
四、 Cron资源:
cron{
"ntpdate":
command => "/usr/sbin/ntpdate pool.ntp.org",
user => root,
hour => 0,
minute => 0,
}
意思是在客户端写入一个计划任务:0 0* * */usr/sbin/ntpdate pool.ntp.org 自动同步时间!
五、向客户端推送本地脚本:
首先修改vi /etc/puppet/fileserver.conf 文件,添加如下三行:
path/etc/puppet/files
allow *
然后cp所需要的脚本到 /etc/puppet/files目录,没有这个目录则新建!
file {
"/tmp/nginx_install.sh":
source => "puppet://master.puppet.com/files/nginx_install.sh",
group => root,
owner => root,
mode => "755"
}
意思是把 /etc/puppet/files/nginx_install.sh这个脚本推送到客户端的/tmp/下!
六、Exec远程执行脚本:
如第五步,我们把nginx_install.sh推送过去后,这时候我们就可以执行了如下:
exec {
"/tmp/nginx_install.sh":
cwd => "/tmp",
user => root,
path => ["/usr/bin","/usr/sbin","/bin","/bin/sh"],
}
这样的配置后,你可以在客户端测试,测试结果已经自动安装完nginx!如下结果
# puppetd --server=master.puppet.com --test
info: Caching catalog for master.puppet.com
info: Applying configuration version '1337450399'
notice: /Stage//Node/Exec/returns: executed successfully
notice: Finished catalog run in 49.96 seconds
但是这里有个地方需要注意,这每次同步都会执行这个脚本,所以我们要设置一个参数,如果nginx_install.sh有更新才执行:
exec {
"/tmp/nginx_install.sh":
cwd => "/tmp",
user => root,
path => ["/usr/bin","/usr/sbin","/bin","/bin/sh"],
subscribe => File["/tmp/nginx_install.sh"],
refreshonly => true;
}
七、执行命令:
###更新sysctl.conf
file { "/etc/sysctl.conf":
source => "puppet://master.puppet.com/files/sysctl.conf",
owner => "root",
group => "root",
mode => 644,
}
exec {
"sysctl refresh kernel config":
path => ["/usr/bin", "/usr/sbin", "/bin", "/sbin"],
command=> "/sbin/sysctl -p",
subscribe => File["/etc/sysctl.conf"],
refreshonly => true
}
有更新才在客户端执行!如果没有更新则不执行!
更深入的moudules配置、更多资源等内容后期不断更新!
学习了,不错,讲的太有道理了 此地禁止大小便,违者没收工具。 怀揣两块,胸怀500万! 我本非随便的人,但如果你想随便,那我就随你的便好啦! 过来看看的 避孕的效果:不成功,便成“人”。
页:
[1]