Saltstack之Scheduler

1、引言:html

  在平常的运维工做中常常会遇到须要定时定点启动任务,首先会考虑到crontab,可是经过crontab的话须要每台机器下进行设置,这样统一管理的话比较复杂;经过查百度和google发现saltstack有scheduler的功能。运维

2、Pillar Scheduler:google

  Salt自己提供多方面的Scheduler的配置,分别有3种配置方式:spa

  一、从Master配置端;code

  二、Master Pillar端;htm

  三、Minion配置端或者Minion.d下配置文件下配置blog

  在这里介绍的是pillar的方式;官方文档:https://docs.saltstack.com/en/latest/topics/jobs/index.htmlcrontab

  首先建立一个/srv/salt/pillar/top.sls文档

[root@test pillar]# cat /srv/salt/pillar/top.sls
base:
  "*":
    - schedule

  而后建立/srv/salt/pillar/schedule.slsget

[root@test tmp]# cat /srv/salt/pillar/schedule.sls
schedule:
  testcase:
    function: cmd.run
    seconds: 10
    args:
      - 'date >> /tmp/test.cmd.log'
    kwargs:
      stateful: False

备注:这个调度任务的意思是:每隔10秒在/tmp目录下的test.cmd.log文件中记录一条时间。

  建立完文件以后执行下面的命令把pillar的修改刷到minion端。

salt "*" saltutil.refresh_pillar

  想查看minion端都有哪些计划任务能够用:

[root@test pillar]# salt "*" pillar.get schedule
192.168.1.88:
    ----------
    __mine_interval:
        ----------
        function:
            mine.update
        jid_include:
            True
        maxrunning:
            2
        minutes:
            60
        name:
            __mine_interval
    testcase:
        ----------
        args:
            - date >> /tmp/test.cmd.log
        function:
            cmd.run
        jid_include:
            True
        kwargs:
            ----------
            stateful:
                False
        maxrunning:
            1
        name:
            testcase
        seconds:
            10

或者:

[root@test pillar]# salt "*" config.option schedule
192.168.1.88:
    ----------
    __mine_interval:
        ----------
        function:
            mine.update
        jid_include:
            True
        maxrunning:
            2
        minutes:
            60
        name:
            __mine_interval

  config.option的方式只能出mine.update的。

3、运行结果:

[root@test pillar]# tail -f /tmp/test.cmd.log 
Tue Mar 21 14:26:58 CST 2017
Tue Mar 21 14:27:08 CST 2017
Tue Mar 21 14:27:18 CST 2017
Tue Mar 21 14:27:28 CST 2017
Tue Mar 21 14:27:38 CST 2017
Tue Mar 21 14:27:48 CST 2017
Tue Mar 21 14:27:58 CST 2017
Tue Mar 21 14:28:08 CST 2017
Tue Mar 21 14:28:18 CST 2017
Tue Mar 21 14:28:28 CST 2017
相关文章
相关标签/搜索