黑帽联盟

 找回密码
 会员注册
查看: 921|回复: 0
打印 上一主题 下一主题

[基础服务] ansible笔记(7):常用模块之系统类模块

[复制链接]
yun 黑帽联盟官方人员 

920

主题

37

听众

1364

积分

超级版主

Rank: 8Rank: 8

  • TA的每日心情
    奋斗
    2019-10-18 11:20
  • 签到天数: 678 天

    [LV.9]以坛为家II

    本帖最后由 yun 于 2019-9-11 17:20 编辑

    ansible是一个系列文章,我们会尽量以通俗易懂的方式总结ansible的相关知识点。
    ansible系列博文直达链接:ansible轻松入门系列
    "ansible系列"中的每篇文章都建立在前文的基础之上,所以,请按照顺序阅读这些文章,否则有可能在阅读中遇到障碍。


    前文中,我们介绍了一些常用的文件类模块和命令类模块,这篇文章中我们会介绍一些常用的系统类操作模块。

    cron模块
    cron模块可以帮助我们管理远程主机中的计划任务,功能相当于crontab命令。

    在了解cron模块的参数之前,先写出一些计划任务的示例,示例如下
    #示例1
    5 1 * * * echo test
    #示例2
    1 1 */3 * * echo test
    #示例3
    @reboot echo test
    #示例4
    @hourly echo test

    上述示例1表示每天的1点5分输出test字符
    上述示例2表示每3天执行一次计划任务,于当天的1点1分执行,具体任务为输出test字符
    上述示例3表示每次系统启动后需要执行一次计划任务,具体任务为输出test字符
    上述示例4表示每小时执行一次计划任务,具体任务 为输出test字符

    根据上述示例,可以更好的了解cron模块的参数

    cron模块通常使用的参数如下,你可以先大概的了解一下这些参数,然后再结合后面的示例去理解:
    minute参数:此参数用于设置计划任务中分钟设定位的值,比如,上述示例1中分钟设定位的值为5,即minute=5,当不使用此参数时,分钟设定位的值默认为"*"
    hour参数:此参数用于设置计划任务中小时设定位的值,比如,上述示例1中小时设定位的值为1,即hour=1,当不使用此参数时,小时设定位的值默认为"*"
    day参数:此参数用于设置计划任务中日设定位的值,当不使用此参数时,日设定位的值默认为"*"
    month参数:此参数用于设置计划任务中月设定位的值,当不使用此参数时,月设定位的值默认为"*"
    weekday参数:此参数用于设置计划任务中周几设定位的值,当不使用此参数时,周几设定位的值默认为"*"
    special_time参数:在上述示例3与示例4中,计划任务的时间设定格式为@reboot或者@hourly,@reboot表示重启时执行,@hourly表示每小时执行一次,相当于设置成"0 * * * *" ,这种@开头的时间设定格式则需要使用special_time参数进行设置,special_time参数的可用值有reboot(重启后)、yearly(每年)、annually(每年,与yearly相同)、monthly(每月)、weekly(每周)、daily(每天)、hourly(每时)。
    注意:当上述时间单位设定参数都未指定时,计划任务的时间设定默认会被设定为"* * * * *",这样表示每分钟都会执行一次计划任务,所以,在使用cron模块时,我们应该确定对应的时间参数设置正确。
    user参数:此参数用于设置当前计划任务属于哪个用户,当不使用此参数时,默认为管理员用户
    job参数:此参数用于指定计划的任务中需要实际执行的命令或者脚本,比如上例中的"echo test"命令。
    name参数:此参数用于设置计划任务的名称,计划任务的名称会在注释中显示,当不指定计划任务的名称时,ansible会默认为计划任务加入注释,注释的内容为#Ansible: None,假设指定计划任务的名称为test,那么注释的内容为#Ansible: test,在一台机器中,计划任务的名称应该具有唯一性,方便我们以后根据名称修改或删除计划任务。
    state参数:当计划任务有名称时,我们可以根据名称修改或删除对应的任务,当删除计划任务时,需要将state的值设置为absent
    disabled参数:当计划任务有名称时,我们可以根据名称使对应的任务"失效"(注释掉对应的任务),注意,使用此参数时,除了需要指定任务的名称,还需要同时指定任务的job以及任务的时间设定,而且任务的时间设定必须和对应任务完全相同,否则在注释任务的同时,任务的时间设定会被修改,除非你确定这样做,如果你不明白这段话的意思,可以参考下文中的示例。
    backup参数:如果此参数的值设置为yes,那么当修改或者删除对应的计划任务时,会先对计划任务进行备份,然后再对计划任务进行修改或者删除,cron模块会在远程主机的/tmp目录下创建备份文件,以crontab开头并且随机加入一些字符,具体的备份文件名称会在返回信息的backup_file字段中看到,推荐将此此参数设置为yes。

    cron模块的ad-hoc示例命令如下:

    在test70主机上创建计划任务,任务名称为"test crontab",任务于每天1点5分执行,任务内容为输出test字符
    1. ansible test70 -m cron -a " name='test crontab' minute=5 hour=1 job='echo test' "
    复制代码
    执行上述命令后,在test70主机中root用户下会有如下计划任务被创建
    #Ansible: test crontab
    5 1 * * * echo test

    在test70主机上创建计划任务,任务名称为"crontab day test",任务每3天执行一次,于执行当天的1点1分开始执行,任务内容为输出test字符
    1. ansible test70 -m cron -a " name='crontab day test' minute=1 hour=1 day=*/3 job='echo test' "
    复制代码
    执行上述命令后,在test70主机中root用户下会有如下计划任务被创建
    #Ansible: crontab day test
    1 1 */3 * * echo test

    在test70主机上创建计划任务,任务名称为"test special time",任务将在重启时执行,任务内容为输出test字符
    1. ansible test70 -m cron -a " name='test special time' special_time=reboot job='echo test' "
    复制代码
    执行上述命令后,在test70主机中root用户下会有如下计划任务被创建
    #Ansible: test special time
    @reboot echo test

    在test70主机上创建计划任务,任务名称为"test special time",任务将在重启时执行,任务内容为输出test字符
    1. ansible test70 -m cron -a " name='test special time' special_time=reboot job='echo test' "
    复制代码
    执行上述命令后,在test70主机中root用户下会有如下计划任务被创建
    #Ansible: test special time
    @reboot echo test

    由于"test special time"已经存在,所以,当我们再次操作同名的任务时,ansible将会认为是修改原来的任务。
    在"test special time"已经存在的情况下,执行如下命令,原计划任务会被修改,因为启用了backup,所以任务在修改前会被备份。
    1. ansible test70 -m cron -a " name='test special time' special_time=hourly job='echo test' backup=yes "
    复制代码
    执行上述命令后,从返回信息的backup_file字段中可以看到备份文件的远程主机中的位置,原来的"test special time"任务会变成如下设定
    #Ansible: test special time
    @hourly echo test

    任务"test special time"已经存在于test70主机中,如果我们想要删除这个计划任务,可以执行如下命令,删除任务的同时可以进行备份。
    1. ansible test70 -m cron -a " name='test special time' state=absent backup=yes "
    复制代码
    命令执行后,从返回信息的backup_file字段中可以看到备份文件的远程主机中的位置

    默认操作root用户的计划任务,如果想要操作远程主机中其他用户的计划任务,可以指定要操作的用户
    1. ansible test70 -m cron -a "user=zsy name='test special time' special_time=hourly job='echo test'"
    复制代码
    上述命令执行后,可以在远程主机中使用crontab -lu zsy查看对应的计划任务。

    之前已经创建了名称为test crontab的计划任务,如果我们想要暂时注释这个计划任务,可以使用如下命令,但是需要注意,在注释任务时,所有设定需要 跟原设定保持一致,否则计划任务的设置将会发生改变,示例如下
    比如,我们想要将crontab day test这个任务注释掉,则需要使用如下命令,注意,最好与backup参数同时使用
    1. ansible test70 -m cron -a " name='crontab day test' minute=1 hour=1 day=*/3 job='echo test'  disabled=yes backup=yes"
    复制代码
    执行上述命令后,对应的计划任务将会被注释,如下
    #Ansible: crontab day test
    #1 1 */3 * * echo test
    如果你在使用disabled参数时,设置了错误的时间,那么对应任务被注释的同时,时间设定也会发生改变,比如,如果你执行了如下命令
    1. ansible test70 -m cron -a " name='crontab day test' minute=55 job='echo test'  disabled=yes backup=yes"
    复制代码
    那么对应任务被注释的同时,同时还会进行如下设置
    #Ansible: crontab day test
    #55 * * * * echo test
    如果你忘记了任何时间设定,那么在任务被注释时,还会被设置为默认的时间设定,也就是 "* * * * *"
    所以,在使用disabled参数时,最后结合backup参数一起使用,万一一时大意,还有回旋的余地。
    service模块
    service模块可以帮助我们管理远程主机上的服务,比如,启动或停止远程主机中的nginx服务。
    注意:假如你想要管理远程主机中的某个服务,那么这个服务必须能被 BSD init, OpenRC, SysV, Solaris SMF, systemd, upstart 中的任意一种所管理,否则service模块也无法管理远程主机的对应服务,这样说可能不容易理解,那么我们换个方式来解释,假设你在使用centos6,那么你的centos6中的nginx则必须能够通过"service nginx start"启动,如果你的nginx无法通过"service nginx start"进行启动,那么它将同样无法通过ansible的service模块启动,假设你在使用centos7,那么你的centos7中的nginx则必须能够通过"systemctl start nginx"启动,如果它无法通过"systemctl start nginx"进行启动,那么它将同样无法通过ansible的service模块进行启动,centos6中默认通过sysv管理服务,centos7中默认通过systemd管理服务,如果你的服务无法通过 BSD init, OpenRC, SysV, Solaris SMF, systemd, upstart 中的任意一种所管理,那么它也无法被ansible的service模块管理。

    service模块通常使用的参数如下,你可以先大概的了解一下这些参数,然后再结合后面的示例去理解:
    name参数:此参数用于指定需要操作的服务名称,比如nginx
    state参数:此参数用于指定服务的状态,比如,我们想要启动远程主机中的nginx,则可以将state的值设置为started,如果想要停止远程主机中的服务,则可以将state的值设置为stopped,此参数的可用值有started、stopped、restarted、reloaded。
    enabled参数:此参数用于指定是否将服务设置为开机 启动项,设置为yes表示将对应服务设置为开机启动,设置为no表示不会开机启动。

    service模块的ad-hoc示例命令如下:

    将test70中的nginx服务处于启动状态
    1. ansible test70 -m service -a "name=nginx state=started"
    复制代码
    将test70中的nginx服务处于停止状态
    1. ansible test70 -m service -a "name=nginx state=stopped"
    复制代码
    将test70中的nginx服务被设置为开机自动启动项
    1. ansible test70 -m service -a " name='nginx' enabled=yes"
    复制代码
    帖子永久地址: 

    黑帽联盟 - 论坛版权1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与黑帽联盟享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和黑帽联盟的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、黑帽联盟管理员和版主有权不事先通知发贴者而删除本文

    您需要登录后才可以回帖 登录 | 会员注册

    发布主题 !fastreply! 收藏帖子 返回列表 搜索
    回顶部