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,如需转载请自行联系原作者



相关文章
|
3天前
|
存储 算法 数据挖掘
服务器数据恢复—昆腾存储StorNext文件系统数据恢复案例
服务器数据恢复环境: 昆腾某型号存储,8个存放数据的存储柜+1个存放元数据的存储柜。 元数据存储:8组RAID1阵列+1组RAID10阵列+4个全局热备硬盘。 数据存储:32组RAID5阵列,划分2个存储系统。 服务器故障: 数据存储的1个存储系统中的一组RAID5阵列中有2块硬盘先后出现故障离线,导致该RAID5阵列失效,整个存储系统崩溃不可用。
服务器数据恢复—昆腾存储StorNext文件系统数据恢复案例
|
1月前
|
定位技术
GPS北斗卫星同步时钟(时间同步服务器)建设施工部署方案
GPS北斗卫星同步时钟(时间同步服务器)建设施工部署方案
GPS北斗卫星同步时钟(时间同步服务器)建设施工部署方案
|
2月前
|
数据挖掘 Linux
服务器数据恢复-重装系统导致XFS分区丢失的数据恢复案例
服务器数据恢复环境: MD1200磁盘柜中的磁盘通过RAID卡创建了一组RAID5阵列,分配了一个LUN。在Linux操作系统层面对该LUN进行了分区,划分sdc1和sdc2两个分区,通过LVM扩容的方式将sdc1分区加入到了root_lv中;sdc2分区格式化为XFS文件系统。 服务器故障: 服务器重装系统后,磁盘分区改变,sdc2分区丢失,无法访问。
服务器数据恢复-重装系统导致XFS分区丢失的数据恢复案例
|
1月前
|
存储 数据挖掘 Windows
服务器数据恢复—异常断电导致raid信息丢失的数据恢复案例
由于机房多次断电导致一台服务器中raid阵列信息丢失。该阵列中存放的是文档,上层安装的是Windows server操作系统,没有配置ups。 因为服务器异常断电重启后,raid阵列可以正常使用,所以未引起管理员的注意。后续出现的多次异常断电导致raid报错,服务器无法找到存储设备,进入raid管理模块进行任何操作都会导致操作系统死机。管理员尝试多次重启服务器,故障依旧。
|
1月前
|
存储 运维 安全
服务器数据恢复—存储互斥不当导致VMFS卷损坏的数据恢复案例
某公司的信息管理平台,通过3台虚拟机共享了一台存储设备供企业内部使用,存储设备中存放了公司内部重要的数据文件。 由于业务增长的需要,管理员又在这个存储网络上连接了一台Windows server服务器,结果这台存储变得不可用了。 管理员对该存储进行故障排查时发现存储中虚拟磁盘丢失,分区表丢失。重启该存储设备后故障依旧。 由于存储中的数据十分重要,没有备份。管理员为了安全起见,联系北亚企安数据恢复中心寻求帮助。 经过硬件工程师的检测,没有发现存储存在硬件故障。存储中的硬盘经过硬件工程师的检测后也没有发现任何物理故障,都可以正常读取。基本上可以排除故障是由于硬件导致的。
|
1月前
|
数据挖掘
服务器数据恢复—服务器硬盘掉线,指示灯显示红色的数据恢复案例
一台服务器中有一组由多块硬盘组建的raid阵列,在运行过程中服务器突然崩溃,管理员检查服务器发现该服务器raid阵列中有两块硬盘的指示灯显示红色。于是,管理员重启服务器,服务器重启后,先离线的硬盘上线并开始自动同步数据,数据同步过程中管理员又将服务器强制关机。
服务器数据恢复—服务器硬盘掉线,指示灯显示红色的数据恢复案例
|
1月前
|
消息中间件 关系型数据库 MySQL
Flink CDC产品常见问题之把flink cdc同步的数据写入到目标服务器失败如何解决
Flink CDC(Change Data Capture)是一个基于Apache Flink的实时数据变更捕获库,用于实现数据库的实时同步和变更流的处理;在本汇总中,我们组织了关于Flink CDC产品在实践中用户经常提出的问题及其解答,目的是辅助用户更好地理解和应用这一技术,优化实时数据处理流程。
|
1月前
|
存储 数据挖掘
服务器数据恢复—raid5热备盘同步失败的数据恢复案例
一台存储上有一组由多块硬盘组建的raid5阵列,该raid5阵列中的一块硬盘掉线,热备盘自动上线同步数据的过程中,raid阵列中又有一块硬盘掉线,热备盘的数据同步被中断,raid5阵列失效,卷挂载不上,存储瘫痪。 这类raid故障比较常见,服务器raid中的硬盘大多数情况下都是一个批次的同品牌同型号的硬盘,一旦有硬盘出现故障掉线,那么其他硬盘也随时有出故障掉线的可能。
|
1月前
|
存储 Oracle 关系型数据库
服务器数据恢复—北亚企安服务器数据恢复案例集锦
服务器数据恢复案例之服务器raid6中3个磁盘离线导致阵列崩溃的数据恢复案例 服务器数据恢复案例之服务器RAID5两个磁盘指示灯显示红色导致服务器崩溃的数据恢复案例 服务器数据恢复案例之服务器硬盘出现坏道/坏扇区离线导致服务器崩溃的数据恢复案例
|
1月前
|
存储 网络协议 数据可视化
如何使用Synology Drive作为文件同步服务器实现云同步Obsidian笔记
如何使用Synology Drive作为文件同步服务器实现云同步Obsidian笔记

推荐镜像

更多