阿牛 发表于 2018-8-3 08:53:32

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配置、更多资源等内容后期不断更新!
  本文出自 “烟雨楼台” 博客,请务必保留此出处http://wgkgood.blog.51cto.com/1192594/869767
页: [1]
查看完整版本: puppet 管理、配置