1
0
Fork 0
mirror of https://github.com/Luzifer/elastic_cron.git synced 2024-12-22 18:31:20 +00:00
This project is a quick and dirty replacement for running a cron daemon inside docker containers
Find a file
Knut Ahlers a96c50867b
Add meta files
Signed-off-by: Knut Ahlers <knut@ahlers.me>
2017-04-02 14:12:09 +02:00
.gitignore Initial version 2016-02-26 18:44:10 +01:00
config.yml Initial version 2016-02-26 18:44:10 +01:00
CONTRIBUTING.md Add meta files 2017-04-02 14:12:09 +02:00
History.md Prepared release 0.1.0 2016-02-26 22:32:57 +01:00
LICENSE Add meta files 2017-04-02 14:12:09 +02:00
main.go Allow log format to be configured 2017-04-02 14:06:41 +02:00
README.md Added README 2016-02-26 22:31:51 +01:00
syslog.go Allow log format to be configured 2017-04-02 14:06:41 +02:00

Luzifer / rsyslog_cron

This project is a quick and dirty replacement for running a cron daemon inside docker containers.

Advantages

  • It logs the output of the jobs into a remote syslog target (like Papertrail) using TCP syslog
  • Crons can be started on seconds, not only on minutes like a conventional cron
  • Due to the logs cron jobs can get debugged

Usage

  1. Put the binary into your container
  2. Generate a YAML file containing the cron definition
  3. Watch your crons get executed in your log stream

Config format

---
rsyslog_target: logs.myserver.com:12345
jobs:
  - name: date
    schedule: "0 * * * * *"
    cmd: "/bin/date"
    args:
      - "+%+"

The rsyslog_target parameter needs to be a rsyslog endpoint supporting TCP plain connections like Loggly or Papertrail does.

The schedule parameter consists of 6 instead of the normal 5 fields:

field         allowed values
-----         --------------
second        0-59
minute        0-59
hour          0-23
day of month  1-31
month         1-12 (or names, see below)
day of week   0-7 (0 or 7 is Sun, or use names)

Standard format for crontab entries is supported. (See man 5 crontab)