puppet自动化运维之exec资源

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
日志服务 SLS,月写入数据量 50GB 1个月
简介:

Puppet通过exec来执行外部的命令或者脚本,一般来讲是shell脚本。

这里面就涉及到一个重复执行的问题,因为默认的agent一连接上来就会自动执行对应的命令或者脚本。如果脚本重复执行对系统没影响的还无所谓,如果会对系统造成影响呢?

一个有用的方法是使用像creates参数来,除非达到了某个条件才会运行命令。比如执行之前判断文件是否存在等等。你可以使用refreshonly参数限制一个exec只有收到某个事件才执行。

 

作用:

    ①、远程执行系统命令,其实就是shell的调用;

②、由于exec是一次性执行资源,在不同类里面exec名字可相同。

 

格式:


exec {"title":              #一般写上要执行的命令,如不写,则需要指定command

    cwd => "目录的绝对路径",    #在那个目录下执行,也可不要

    path =>   "/bin:/sbin:...",   #命令执行的搜索路径,如不要,需指定命令的绝对路径

    command => "执行的命令",    #写上要执行的命令,一般不需要,可在title中写上

    creates => "文件名(绝对路径)",#当且仅当,该文件名不存在,命令才被执行,可不要

    user => "用户名",       #定义运行命令的用户。 注意如果你使用了这个参数,那么任何的错误输出不会在当下被捕捉

    logoutput =>   "true|false",  #是否记录输出,可取的值为:true,false和其他合法的日志等级。

    onlyif => "命令",       #如onlyif中命令的执行结果为0(执行正确),才执行title或command中的目录,与unless相反

    unless => "命令",       #如unless中命令的执行结果不为0(执行出错),才执行title或command中的目录,与onlyif相反

}

 


puppet执行外部命令,多次反复用这个方式执行命令是有威胁性的,因此建议对执行的命令进行加锁或者类似的处理.

建议每个exec资源的名字最好是唯一的.

建议属性值的目录、命令或文件,最好是绝对路径

 

exec 参数介绍:

 

command     command => "执行的命令",

将会被执行的命令,必须为被执行命令的绝对路径,或者得提供该命令的搜索路径。如果命令被成功执行,所有的输出会被记录在实例的正常(normal)日志里,但是如果命令执行失败(既返回值与我们所指定的不同),那么所有的输出会在错误(err)日志中被记录。这个是exec资源类型的名变量(namevar)。

 

creates     creates => "文件名(绝对路径)",

指定命令所生成的文件。如果提供了这个参数,那么命令只会在所指定的文件不存在的情况的被执行,下次的时候,该文件存在了,就不在执行命令。

create属性表明该exec将创建一个文件,当下一次puppet执行的时候,如果发现了这个文件,就不再执行这个exec资源。

 

cwd         cwd => "目录的绝对路径",

指定命令执行的目录。如果目录不存在,则命令执行失败。

 

user        user => "用户名",

定义运行命令的用户。 注意如果你使用了这个参数,那么任何的错误输出不会在当下被捕捉,这是Ruby的一个bug。

If you are using Puppet to create this user, the exec will automatically require the user, as long as it is specified by name

 

onlyif      onlyif => "命令",

如onlyif中命令的执行结果为0(执行正确),才执行title或command中的目录,与unless相反。例如:

exec { "logrotate": path => "/usr/bin:/usr/sbin:/bin", onlyif => "test `du /var/log/messages | cut -f1` -gt 100000" }

只有在test返回true的时候logrotate才会被运行。

需要注意的是onlyif定义的命令跟主命令遵循同样的规则,也就是说如果path没有被设置的话,需要使用绝对路径。

除此之外,onlyif还可以接受数组做为其值,例如:

onlyif => ["test -f /tmp/file1", "test -f /tmp/file2"]

上面的代码限定了只有在所有数组中的条件返回true时exec才会被执行。

 

unless      unless => "命令",

如unless中命令的执行结果不为0(执行出错),才执行title或command中的目录,与onlyif相反。例如:

exec { "/bin/echo root >> /usr/lib/cron/cron.allow":

            path => "/usr/bin:/usr/sbin:/bin",

            unless => "grep root /usr/lib/cron/cron.allow 2>/dev/null"

            }

上面这段代码先用grep在cron.allow文件(Solaris系统中)中找root,如果没有找到,就写入root。

要注意的是这个参数里的命令跟主命令遵循同样的规则,也就是说如果path没有被设置的话,需要使用绝对路径。

 

path        path => "/bin:/sbin:...",

命令执行的搜索路径。如果path没有被定义,命令需要使用绝对路径。路径可以以数组或以冒号分隔的形式来定义。

 

logoutput   logoutput => "true|false|on_failure",

是否记录输出。默认会根据exec资源的日志等级(loglevel) 来记录输出。若定义为on_failure,则仅在命令返回错误的时候记录输出。可取的值为:true,false和其他合法的日志等级。

 

env:

我们不建议使用这个参数,请使用‘environment’。这一部分还未完成。

 

environment

为命令设定额外的环境变量。要注意的是如果你用这个来设定PATH,那么PATH的属性会被覆盖。多个环境变量应该以数组的形式来设定。

 

group

定义运行命令的用户组。在不同的平台下的运行的结果无法确定,由于不同用户运行命令的时候,变量是不变的,所以这是平台的问题,而不是Ruby或Puppet的问题。

 

refresh

定义如何更新命令。当exec收到一个来自其他资源的事件时,默认只会重新执行一次命令。不过这个参数允许你定义更新时执行不同的命令。

 

refreshonly

该属性可以使命令变成仅刷新触发的,也就是说只有在一个依赖的对象被改变时,命令才会被执行。仅当命令与其他对象有依赖关系时,这个参数才有意义。当你要触发某个行为时,会显得很有用:

file { "/etc/aliases":

source =>   "puppet://server/module/aliases"

}

exec { newaliases:

path =>   ["/usr/bin", "/usr/sbin"],

subscribe =>   File["/etc/aliases"],

refreshonly => true

}

 

要注意的是只有subscribe和notify可以促发行为,而不是require,所以在使用refreshonly时,只有同时使用subscribe或notify才有意义。有效的值为true, false。

returns

指定返回的代码。如果被执行的命令返回了其他的代码,一个错误(error)会被返回。默认值是0,可以定义为一个由可以接受的返回代码组成的数组或单值。

 

timeout     timeout => "秒数",

命令运行的最长时间。如果命令运行的时间超过了timeout定义的时间,那么这个命令就会被终止,并作为运行失败处理。当定义为负值时就会取消运行时间的限制。timeout的值是以秒为单位的。

 

exec资源在不到万不得已的时候不要去用,简单说来exec资源就是在执行puppet的时候,调用shell执行一条shell语句,例如:

exec {"delete config":

path => "/bin:/usr/bin",

command => "rm /etc/ssh/ssh_config";

}

  

exec资源是不太好掌控的资源,如果能用脚本实现,尽量写成脚本通过file资源分发到服务器上面。然后用其他的方式来调用脚本。例如crontab。或你完全可以用file资源来把crontab任务放到/etc/cron.d目录下来实现crontab资源的管理。使用puppet的时候,尽量用最简单的语法,越是花哨的语法也越容易出错。

 

实例:

#creates

vi /etc/puppet/manifest/test.pp

#注意命令要使用绝对路径

Exec { path => [ "/bin/", "/sbin/" ,   "/usr/bin/", "/usr/sbin/" ] }

 

exec { "/tmp/test1":

         command =>   "touch /tmp/exec_test1",

         creates =>   "/tmp/exec_test1";

}

 

#check

[root@client ~]# ll /tmp/exec_test1

ls: cannot access /tmp/exec_test1: No such file or directory

[root@client ~]#

[root@client ~]# puppet agent --test -v --server   master.perofu.com

info: Caching catalog for client.perofu.com

info: Applying configuration version '1395071830'

notice: /Stage[main]//Exec[/tmp/test1]/returns:   executed successfully

notice: Finished catalog run in 0.32 seconds

[root@client ~]#

[root@client ~]# ll /tmp/exec_test1                              

-rw-r--r-- 1 root root 0 Mar 17 23:58 /tmp/exec_test1

[root@client ~]#

#此时creates的参数已满足,就不会再执行了

[root@client ~]# puppet agent --test -v --server   master.perofu.com

info: Caching catalog for client.perofu.com

info: Applying configuration version '1395071830'

notice: Finished catalog run in 0.23 seconds

[root@client ~]#

[root@client ~]# ll /tmp/exec_test1                              

-rw-r--r-- 1 root root 0 Mar 17 23:58 /tmp/exec_test1

[root@client ~]#

 

#onlyif

Exec { path => [ "/bin/", "/sbin/" ,   "/usr/bin/", "/usr/sbin/" ] }

 

exec {"rm -rf /var/log/mysqld.log.bak":

        logoutput => "on_failure",

        onlyif =>   "[ $(cat /var/log/mysqld.log.bak |wc -l) -gt 10 ]";

 

}

 

#check

[root@client ~]# cat /var/log/mysqld.log.bak |wc -l

21

[root@client ~]# [ `cat /var/log/mysqld.log.bak |wc -l` -gt   10 ]

[root@client ~]# echo $?

0

[root@client ~]# puppet agent --test -v --server   master.perofu.com

info: Caching catalog for client.perofu.com

info: Applying configuration version '1395072287'

notice: /Stage[main]//Exec[rm -rf   /var/log/mysqld.log.bak]/returns: executed successfully

notice: Finished catalog run in 0.38 seconds

[root@client ~]# ll /var/log/mysqld.log.bak

ls: cannot access /var/log/mysqld.log.bak: No such file or directory





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






相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
运维 Linux Apache
Puppet 作为一款强大的自动化运维工具,被广泛应用于配置管理领域。通过定义资源的状态和关系,Puppet 能够确保系统始终处于期望的配置状态。
Puppet 作为一款强大的自动化运维工具,被广泛应用于配置管理领域。通过定义资源的状态和关系,Puppet 能够确保系统始终处于期望的配置状态。
64 3
|
2月前
|
运维 Linux Apache
Puppet这一强大的自动化运维工具,涵盖其基本概念、安装配置及使用示例
【10月更文挑战第8天】本文介绍了Puppet这一强大的自动化运维工具,涵盖其基本概念、安装配置及使用示例。Puppet通过定义资源状态和关系,确保系统配置始终如一,支持高效管理基础设施。文章详细讲解了Puppet的安装步骤、配置方法及DSL语言示例,帮助读者快速掌握Puppet的使用技巧。
79 2
|
13天前
|
机器学习/深度学习 运维 监控
智能化运维:从自动化到AIOps的演进之路####
本文深入探讨了IT运维领域如何由传统手工操作逐步迈向高度自动化,并进一步向智能化运维(AIOps)转型的过程。不同于常规摘要仅概述内容要点,本摘要将直接引入一个核心观点:随着云计算、大数据及人工智能技术的飞速发展,智能化运维已成为提升企业IT系统稳定性与效率的关键驱动力。文章详细阐述了自动化工具的应用现状、面临的挑战以及AIOps如何通过预测性分析和智能决策支持,实现运维工作的质变,引领读者思考未来运维模式的发展趋势。 ####
|
13天前
|
机器学习/深度学习 数据采集 人工智能
智能化运维:从自动化到AIOps的演进与实践####
本文探讨了智能运维(AIOps)的崛起背景,深入分析了其核心概念、关键技术、应用场景及面临的挑战,并对比了传统IT运维模式,揭示了AIOps如何引领运维管理向更高效、智能的方向迈进。通过实际案例分析,展示了AIOps在不同行业中的应用成效,为读者提供了对未来智能运维趋势的洞察与思考。 ####
34 1
|
25天前
|
机器学习/深度学习 数据采集 人工智能
智能运维:从自动化到AIOps的演进与实践####
本文探讨了智能运维(AIOps)的兴起背景、核心组件及其在现代IT运维中的应用。通过对比传统运维模式,阐述了AIOps如何利用机器学习、大数据分析等技术,实现故障预测、根因分析、自动化修复等功能,从而提升系统稳定性和运维效率。文章还深入分析了实施AIOps面临的挑战与解决方案,并展望了其未来发展趋势。 ####
|
1月前
|
机器学习/深度学习 数据采集 运维
智能化运维:机器学习在故障预测和自动化响应中的应用
智能化运维:机器学习在故障预测和自动化响应中的应用
57 4
|
2月前
|
存储 运维 监控
高效运维:从基础架构到自动化管理的全面指南
【10月更文挑战第11天】 本文将深入探讨如何通过优化基础架构和引入自动化管理来提升企业IT运维效率。我们将从服务器的选择与配置、存储解决方案的评估,到网络的设计与监控,逐一解析每个环节的关键技术点。同时,重点讨论自动化工具在现代运维中的应用,包括配置管理、持续集成与部署(CI/CD)、自动化测试及故障排除等方面。通过实际案例分析,展示这些技术如何协同工作,实现高效的运维管理。无论是IT初学者还是经验丰富的专业人员,都能从中获得有价值的见解和实操经验。
87 1
|
2月前
|
运维 监控 测试技术
构建高效运维体系:从监控到自动化的实践之路
【10月更文挑战第9天】 在当今信息技术飞速发展的时代,运维作为保障系统稳定性与效率的关键角色,正面临前所未有的挑战。本文将探讨如何通过构建一个高效的运维体系来应对这些挑战,包括监控系统的搭建、自动化工具的应用以及故障应急处理机制的制定。我们将结合具体案例,分析这些措施如何帮助提升系统的可靠性和运维团队的工作效率。
55 1
|
2月前
|
机器学习/深度学习 人工智能 运维
构建高效运维体系:从自动化到智能化的演进
本文探讨了如何通过自动化和智能化手段,提升IT运维效率与质量。首先介绍了自动化在简化操作、减少错误中的作用;然后阐述了智能化技术如AI在预测故障、优化资源中的应用;最后讨论了如何构建一个既自动化又智能的运维体系,以实现高效、稳定和安全的IT环境。
73 4
|
2月前
|
运维 Linux Apache
,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具
【10月更文挑战第7天】随着云计算和容器化技术的发展,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具,通过定义资源状态和关系,确保系统始终处于期望配置状态。本文介绍Puppet的基本概念、安装配置及使用示例,帮助读者快速掌握Puppet,实现高效自动化运维。
63 4

推荐镜像

更多