puppet管理cron(定时同步时间服务器案例)

简介:

用puppet管理cron,可以为N台服务器批量添加cron作业。如定时同步时间服务器的脚本。
1、架构

   192.168.0.200(redhat) 主机名master.gangpao.com
   192.168.0.201(redhat) 主机名agent01.gangpao.com


2、目录结构

   /etc/puppet

        |                 
        |-->manifests                 
        |   |-->modules.pp                 
        |   |-->nodes.pp                 
        |   |-->site.pp                  
        |-->modules                          
            |-->cron                                  
                 |-->manifests
                     |-->addcron.pp
                     |-->base.pp
                     |-->crontabs.pp
                     |-->init.pp                    

3、编写脚本
   建创目录结构

   #mkdir -p /etc/puppet/manifests
   #mkdir -p /etc/puppet/modules/cron/manifests
   #cd /etc/puppet/modules/cron/manifests

 (1)、编写base.pp
    功能说明:安装cron包并启动服务

   #vim
   class cron::base {
    package { cron:
        name => $operatingsystem ? {   #facter 获取客户端操作系统确定包的名称
            ubuntu    => "cron",
            debian    => "cron",
            redhat    => "vixie-cron",
            centos    => "vixie-cron",
            },
        ensure => present,
    }
    service { crond:
        name => $operatingsystem ? {   #确定启动cron的名称
            ubuntu  => "cron",
            debian  => "cron",
            redhat  => "crond",
            centos  => "crond",
            },
        ensure => running,
        enable => true,
        pattern => cron,
        require => Package["cron"],   #依赖关系
    }
}


 (2)、编写crontabs.pp
      功能说明:安装crontabs包

      #vim crontabs.pp
      class cron::crontabs {
         package { crontabs:
              name => $operatingsystem ? {
              redhat  => "crontabs",
              centos  => "crontabs",
              },
              ensure => present,
         }
      }


  (3)、编写addcron.pp
      功能说明:添加crontab定时任务(定时同步时间服务器每4个小时同步的第1分钟同步)

      #vim addcron.pp
      class cron::addcron {
            cron { ntpdate:
               command => "/usr/sbin/ntpdate time-b.timefreq.bldrdoc.gov",
               user => root,
               hour => '*/4',
               minute => '1'
            }
      }


  (4)、编写init.pp
       功能说明:初始化文件

       #vim init.php
       class cron {
             case $operatingsystem {
                 centos: {
                    include cron::base
                    include cron::crontabs
                 }
                  redhat: {
                    include cron::base
                    include cron::crontabs
                    include cron::addcron
     #这三行实现安装添加cron功能
                 }
                 debian: { include cron::base }
                 ubuntu: { include cron::base }
                 freebsd: { }
             }
       }


   (5)、编写主manifests文件实现让客户端安装cron和添加一条crontab作业。

      #cd /etc/puppet/manifests
      #vim modules.pp   #加载cron模块
      import "cron" 
      #vim nodes.pp     #客户端节点管理文件
      node 'agent01.gangpao.com'{
      include cron
      }
      #vim site.pp      #加载modules.pp 和nodes.pp
      import "modules.pp"
      import "nodes.pp"


4、执行脚本
   服务端

   #puppetmasterd -d --no-daemonize -v --trace 


   客户端

   #puppet agent --server master.gangpao.com --test 
   info: Caching catalog for agent01.gangpao.com
   info: Applying configuration version '1310314253'
   notice: /Stage[main]/Cron::Addcron/Cron[ntpdate]/minute: minute    changed   '0' to '1'
   notice: /Stage[main]/Cron::Addcron/Cron[ntpdate]/hour: hour changed   '*/2' to '*/4'
   notice: Finished catalog run in 6.65 seconds

 

查看

[root@agent01 puppet]# crontab -l
# HEADER: This file was autogenerated at Mon Jul 11 00:10:19 +0800 2011 by puppet.
# HEADER: While it can still be managed manually, it is definitely not recommended.
# HEADER: Note particularly that the comments starting with 'Puppet Name' should
# HEADER: not be deleted, as doing so could cause duplicate cron jobs.
# Puppet Name: ntpdate
1 */4 * * * /usr/sbin/ntpdate time-b.timefreq.bldrdoc.gov

 

可以看到客户端的crontab改变了。

爱慕尔商城欢迎您的光临!
穿衣打扮  
城市物语





    本文转自yuangang_love 51CTO博客,原文链接:http://blog.51cto.com/linux008/607854,如需转载请自行联系原作者



相关文章
|
2月前
|
存储 数据挖掘
服务器数据恢复—EMC存储raid5阵列数据恢复案例
服务器存储数据恢复环境: EMC某型号存储中有一组由8块硬盘组建的raid5磁盘阵列。 服务器存储故障: raid5阵列中有2块硬盘离线,存储不可用,上层应用崩了。
|
2月前
|
数据挖掘 Linux
服务器数据恢复—服务器重装系统导致分区改变的数据恢复案例
服务器上有一组由raid卡组建的raid5磁盘阵列。上层安装linux才做系统,采用XFS文件系统,划分了3个分区。 管理员将服务器的操作系统重装后,发现服务器上的分区发生了改变:一个分区消失,其他分区不可访问。
|
2月前
|
存储 运维 数据挖掘
服务器数据恢复—EqualLogic存储硬盘出现坏道的数据恢复案例
一台EqualLogic某型号存储中有一组由16块SAS硬盘组建的RAID5阵列。上层采用VMFS文件系统,存放虚拟机文件,上层一共分了4个卷。 磁盘故障导致存储不可用,且设备已经过保。
|
3月前
|
存储 固态存储 文件存储
服务器数据恢复—NAS存储精简lv的故障的数据恢复案例
NAS数据恢复环境: QNAP TS-532X NAS设备中有两块1T的SSD固态硬盘和3块5T的机械硬盘。三块机械硬盘组建了一组RAID5阵列,两块固态硬盘组建RAID1阵列。划分了一个存储池,并通过精简LVM划分了7个lv。 NAS故障: 硬盘故障导致无法正常进入系统,7个lv分区丢失。
|
4月前
|
存储 Linux 数据库
服务器数据恢复—raid5阵列中多块硬盘出现坏道的数据恢复案例
服务器存储数据恢复环境: 某品牌DS3512存储中有一组由6块SAS磁盘组建的raid5阵列。划分一个lun分配给Linux系统服务器,并格式化成ocfs2文件系统,共享给虚拟化使用,存放虚拟机文件。 存储中的数据包括:数十台iunx系统虚拟机和windows系统虚拟机、压缩包文件、配置文件。 服务器存储故障: raid5阵列中多块硬盘出现问题,阵列崩溃,数据丢失。
|
4月前
|
存储 数据挖掘 数据库
服务器数据恢复—服务器raid磁盘出现故障的数据恢复案例
一台服务器中有一组由三块SAS硬盘组建的raid阵列。服务器上部署的数据库存储在D分区,数据库备份存储在E分区。 服务器上一块硬盘指示灯显示红色。D分区不可识别。E分区虽然可以识别,但是E分区拷贝文件报错。 管理员重启服务器,先离线的硬盘上线开始同步数据,同步没有完成的情况下管理员将服务器强制关机,之后没有动过服务器。
|
4月前
|
数据挖掘
服务器数据恢复—服务器raid5阵列中2块硬盘掉线的数据恢复案例
某公司一台服务器,服务器上有一组由8块硬盘组建的raid5磁盘阵列。 磁盘阵列中2块硬盘的指示灯显示异常,其他硬盘指示灯显示正常。上层应用不可用。
|
3月前
|
存储 网络安全 PHP
在阿里云服务器上如何搭建网站,网址怎么建站图文教程详解案例及步骤.
做好一个网站不仅需要我们对站点装修及内容发布,也需要我们学会对网站运营,如进行站长推送,将我们内容快速推送到各大搜索平台,有效的让用户能搜索到我们内容,或者需要在谷歌推广就必须对网站添加SSL证书,这样搜索域名的时候搜索框不会出现<不安全>字符在域名前面,以及运行网站要懂运维,出现BUG时要去及时解决查找原因.自始至终自身要不断学习网络相关知识,遇到问题方能迎刃而解. 本文结束,如还有不懂的同学可联系作者,倾力而为,祝您成功!
765 73
|
2月前
|
数据挖掘 Linux 数据库
服务器数据恢复—Linux系统服务器数据恢复案例
服务器数据恢复环境: linux操作系统服务器中有一组由4块SAS接口硬盘组建的raid5阵列。 服务器故障: 服务器工作过程中突然崩溃。管理员将服务器操作系统进行了重装。 用户方需要恢复服务器中的数据库、办公文档、代码文件等。
|
1月前
服务器数据恢复—服务器raid5阵列2块硬盘掉线的数据恢复案例
某品牌型号为X3850服务器上有一组由14块数据盘和1块热备盘组建的raid5磁盘阵列。 服务器在正常使用过程中突然崩溃,管理员查看raid5阵列故障情况的时发现磁盘阵列中有2块硬盘掉线,但是热备盘没有启用。

热门文章

最新文章

推荐镜像

更多