-
Notifications
You must be signed in to change notification settings - Fork 39
/
Copy pathREADME
220 lines (157 loc) · 8.9 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
DCRON - DILLON'S LIGHTWEIGHT CRON DAEMON
========================================
**I (dubiousjim) haven't been able to maintain this project for a while and am not actively using the code myself. Here is [a fork](https://github.com/ptchinster/dcron)
with active development. I recommend users to follow there instead, and submit issues and pull requests over there.**
This lightweight cron daemon aims to be simple and secure, with just enough
features to stay useful. It was written from scratch by Matt Dillon in 1994.
It's now developed and maintained by James Pryor.
In the author's opinion, having to combine a cron daemon with another daemon
like anacron makes for too much complexity. So the goal is a simple cron daemon
that can also take over the central functions of anacron.
Unlike other fatter cron daemons, though, this cron doesn't even try to manage
environment variables or act as a shell. All jobs are run with `/bin/sh` for
conformity and portability. We don't try to use the user's preferred shell:
that breaks down for special users and even makes some of us normal users
unhappy (for example, /bin/csh does not use a true O_APPEND mode and has
difficulty redirecting stdout and stderr both to different places!). You can,
of course, run shell scripts in whatever language you like by making them
executable with #!/bin/csh or whatever as the first line. If you don't like
the extra processes, just `exec` them.
If you need to set special environment variables, pass them as arguments to a
script.
The programs were written with an eye towards security, hopefully we haven't
forgotton anything. The programs were also written with an eye towards nice,
clean, algorithmically sound code. It's small, and the only fancy code is that
which deals with child processes. We do not try to optimize with vfork() since
it causes headaches and is rather pointless considering we're execing a shell
most of the time, and we pay close attention to leaving descriptors open in the
crond and close attention to preventing crond from running away.
DOWNLOADING
-----------
The project is hosted at: <http://www.jimpryor.net/linux/dcron.html>.
The latest version is 4.5, which can be downloaded here:
<http://www.jimpryor.net/linux/releases/dcron-4.5.tar.gz>.
A public git repo is available at: <https://github.com/dubiousjim/dcron>.
COMPILING
---------
You must use a compiler that understands prototypes, such as GCC.
(1) The following compile-time defaults are configurable via
command-line assignments on the `make` line (they're shown here with
their default values):
PREFIX=/usr/local # where files will ultimately be installed
SBINDIR = $(PREFIX)/sbin # where crond will be installed
BINDIR = $(PREFIX)/bin # where crontab will be installed
MANDIR = $(PREFIX)/share/man # where manpages will be installed
CRONTABS = /var/spool/cron/crontabs # default dir for per-user crontabs
CRONSTAMPS = /var/spool/cron/cronstamps # default dir
SCRONTABS = /etc/cron.d # default dir for system crontabs
CRONTAB_GROUP = wheel # who's allowed to edit their own crontabs?
LOG_IDENT = crond # syslog uses facility LOG_CRON and this identity
TIMESTAMP_FMT = %b %e %H:%M:%S # used if LC_TIME unset and logging to file
A few additional compile-time settings are defined in defs.h. If you find yourself
wanting to edit defs.h directly, try editing the DEFS line in the Makefile instead.
(2) Run make with your desired settings. For example:
make PREFIX=/usr CRONTAB_GROUP=users
(3) If you're using the git version, you might also want to `make man`,
to be sure the manpages are updated. This requires
[pandoc](http://johnmacfarlane.net/pandoc/).
INSTALLING
----------
(4) `make install` installs the files underneath PREFIX (by default, /usr/local).
If you're packaging, you can supply a DESTDIR argument here:
make DESTDIR=/path/to/your/package/root install
Permissions will be as follows:
-rwx------ 0 root root 32232 Jan 6 18:58 /usr/local/sbin/crond
-rwsr-x--- 0 root wheel 15288 Jan 6 18:58 /usr/local/bin/crontab
Only users belonging to crontab's group (here "wheel") will be able to use it.
You may want to create a special "cron" group and assign crontab to it:
groupadd cron
chgrp cron /usr/local/bin/crontab
chmod 4750 /usr/local/bin/crontab
(If the group already exists, you can specify it by supplying CRONTAB_GROUP
to the `make` or `make install` commands.)
Then add users to group "cron" when you want them to be able to install
or edit their own crontabs. The superuser is able to install crontabs for users
who don't have the privileges to edit their own.
You should schedule crond to run automatically from system startup, using
/etc/rc.local or a similar mechanism. crond automatically detaches. By default
it logs all events <= loglevel NOTICE to syslog.
The crontab files are normally located in /var/spool/cron/crontabs, and timestamps
are normally in /var/spool/cron/cronstamps. These directories normally have permissions:
drwxr-xr-x 2 root root 4096 Jan 6 18:50 /var/spool/cron
drwxr-xr-x 1 root root 0 Jan 6 18:58 /var/spool/cron/crontabs
drwxr-xr-x 1 root root 0 Jan 6 18:58 /var/spool/cron/cronstamps/
Here is the superuser's crontab, created using `sudo crontab -e`:
-rw------- 0 root root 513 Jan 6 18:58 /var/spool/cron/crontabs/root
TESTING
-------
Use the crontab program to create a personal crontab with the following
two lines:
* * * * * date >> /tmp/test
* * * * * date
Check the log output of crond to ensure the cron entries are being
run once a minute, check /tmp/test to ensure the date is being
appended to it once a minute, and check your mail to ensure that crond
is mailing you the date from the other entry once a minute.
After you are through testing cron, delete the entries with `crontab -e`
or `crontab -d`.
EXTRAS
------
The following are included in the "extra" folder. None of them are installed
by `make install`:
crond.rc
: This is an example rc script to start and stop crond. It could be placed in
/etc/rc.d or /etc/init.d in suitable systems.
crond.conf
: This contains user-modifiable settings for crond.rc. The sample crond.rc
expects to source this file from /etc/conf.d/crond.
run-cron
: This simple shell script is a bare-bones alternative to Debian's run-parts.
crond.service
: This is an example sysvinit service to start and stop crond. It
could be placed in /lib/systemd/system in suitable systems.
root.crontab
: This is an example crontab to install for the root user, or to install
in /etc/cron.d. It runs any executable scripts located in the directories /etc/cron.hourly,
/etc/cron.daily, /etc/cron.weekly, and /etc/cron.monthly at the appropriate times.
This example uses the run-cron script mentioned above, and relies on you to
create the /etc/cron.* directories.
prune-cronstamps
: crond never removes any files from your cronstamps directory. If usernames
are abandoned, or cron job names are abandoned, unused files will accumulate
there. This simple cronjob will prune any cronstamp files older than three months.
It will run weekly if placed in /etc/cron.d.
crond.logrotate
: This is an example to place in /etc/logrotate.d. This config file assumes you
run crond using -L /var/log/crond.log. If you run crond using syslog instead (the default),
you may prefer to configure the rotation of all your syslog-generated logs in a
single config file.
crontab.vim
: This makes vim handle backup files in way that doesn't interfere with crontab's security
model.
BUG REPORTS, SUBMISSIONS
------------------------
Send any bug reports and source code changes to James Pryor:
We aim to keep this program simple, secure, and bug-free, in preference to
adding features. Those advanced features we have added recently (such as
@noauto, FREQ= and AFTER= tags, advanced cron.update parsing) fit naturally
into the existing codebase.
Our goal is also to make this program compilable in as near to a C89-strict a
manner as possible. Less-portable features we're aware of are described in the
comments to defs.h. We'll reduce these dependencies as feasible. Do let us know
if any of them are an obstacle to using crond on your platform.
Changes to defs.h, whether to override defaults or to accommodate your platform,
should be made by a combination of a -D option in the Makefile
and an #ifdef for that option in defs.h. Don't rely on pre-definitions made
by the C compiler.
Prototypes for system functions should come from external include
files and NOT from defs.h or any source file. If no prototype exists for a
particular function, contact your vendor to get an update for your includes.
Note that the source code, especially in regard to changing the
effective user, is Linux specific (SysVish). We welcome any changes
in regard to making the mechanism work with other platforms.
CREDITS
-------
We use `concat`, a lightweight replacement for `asprintf`, in order to be more
portable. This was written by Solar Designer and is in the public domain.