# crontab -l 현재사용하고 있는 crontab 파일 출력
# crontab -e crontab 파일의 수정(edit)
crontab -e 로 수정이 안될경우
1. #csh 2. #setenv EDITOR vi 명령 수행후 수정함
root crontab file
/etc/cron.d/logchecker
: /var/cron/log가 최대 화일 크기를 초과하는지를 판단하고, 만약
초과하면 내용을 /var/cron/olog로 복사한다.
/usr/lib/newslog
: syslog daemon에 의해서 /var/adm 디렉토리에 생성되는 log file을 청소한다.
Controlling crontab Access
cron utility를 제어하는 두개의 file
/etc/cron.d/cron.allow
/etc/cron.d/cron.deny
User Access
- cron.allow file이 존재하면, 그 file에 적혀있는 user만이
crontab 명령어를 사용할 수있다.
- 이 file이 없으면 crontab은 cron.deny file을 체크해서 user가 crontab 실행을 금지할 지를 결정한다.
- 만약 둘다 없으면 crontab은 root만 실행시킬 수 있다.
cf) daemon, bin, smtp, nuucp, listen, nobody, noaccess file은 crontab 사용할 수 없다.
- cron.allow file은 user가 만들어 주어야한다.
- crontab 명령어는 crontab file을 수정, 삭제, 편집할 수있다.
- crontab 명령어는 user에대한 입력을 /var/ spool/cron/crontabs/username에 저장한다.
- root 만이 다른 user의 crontab file을 읽고 편집할 수있다.
- root의 crontab file은 /var/spool/cron/crontab/root 이다.
crontab file format
# cd /var/spool/cron/crontabs 에 가신후
# more root
10 3 * * 0,4 /etc/cron.d/logchecker
10 3 * * 0 /usr/lib/newsyslog
15 3 * * 0 /usr/lib/fs/nfs/nfsfind
1 2 * * * [ -x /usr/sbin/rtc ] && /usr/sbin/rtc -c > /dev/null 2>&1
---------- ========================
1 2 3 4 5 program
1 : minute (0-59),
2 : hour (0-23),
3 : day of the month (1-31),
4 : month of the year (1-12),
5 : day of the week (0-6 with 0=Sunday).
이렇게 되고 실행할 파일명을 program 부분에 적어 주면 된다.
파일을 맞게 변경후 cron 데몬을 리스타트시키면 된다.
아니면..리부팅
예로
* * 1 * * /usr/local/program
이렇게 한다면 한달에 한번 매월 1일에만 program 을 실행.
지금 root 파일을 변경했는데 root 파일이 아닌 각계정의 파일을 만들어 사용하면 각유저마다 자동으로 실행할수 있다.
///////////////////////////////////////////////////////////////////////////////////////
crontab 옵션
crontab [ -u user ] file
crontab [ -u user ] { -l | -r | -e }
-u user : user 사용자에 대해서 crontab 작업을 수행한다. 생략하면 crontab 명령을 실행하는 사용자에 대해서 crtontab 작업을 수행.
-l : 현재 cron table을 보여 줌
-r : 현재 cron table을 삭제
-e : 현재 cron table을 편집
일반적으로 crontab -e 명령을 주로 사용한다.
crontab 사용 권한 : /etc/cron.allow, /etc/cron.deny
특정 사용자에게만 cron의 사용을 허가할 경우
/etc/cron.allow 파일에 허가할 사용자만 추가해준다
/etc/cron.deny 파일에 허가하지 않을 사용자를 추가한다
/etc/cron.allow를 먼저 참조한다.
/etc/cron.allow에 명시된 사용자는 cron job을 실행할 수 있다.
/etc/cron.allow에 없는 사용자는, /etc/cron.deny에도 없다면, cron job을 실행할 수 있다.
/etc/cron.allow, /etc/cron.deny 두 파일이 존재하지 않으면 슈퍼 유저만 cron job을 수행할 수 있다.
/etc/cron.deny 파일이 존재하고 아무 내용 없이 비어 있다면, 모든 사용자가 cron job을 수행할 수 있다.
cron table의 각 필드
+-------------------------------------------------------------------+
| 분 | 시간 | 날짜 | 달 | 요일 | 사용자 | 명령 |
+-------------------------------------------------------------------+
minute(0~59) hour(0-23) day(1-31) month(1-12) weekday(1-7) command
<분>은 0-59 <시>는 0-23 <날짜>는 0-31 <달>은 0-12(0또는 12는 12월, 1은 1월...) <요일>은 0-7(0과 7은 일요일, 1은 월요일...)
''*'' : everytime
''-'' : 범위 지정, 예를 들어 시간 필드에 1-3이면 1시와 3시 사이
'','' : separator, 예를 들어 시간 필드에 1,3이면 1시와 3시
/ : 시간필드 에서 23-7/2라면 23시부터 07시까지 매 2시간마다라는 의미
분필드에서 */2라면 매 2분마다라고 해석하면 된다.
사용 예
30 05 * * 1 ~/bin/backup.sh
==> 매주 월요일 오전 05시 30분에 ~/bin/backup.sh을 실행
30 2 1 * * ~/bin/backup.sh
==> 매월 1일 새벽 2시 30분에 ~/bin/backup.sh를 실행
20 1 * * * find /tmp -atime +3 -exec rm -f () '';''
==> 매일 새벽 01시 20분에 3일간 접근하지 않은 /tmp내의 파일을 삭제
~