본문 바로가기

Language&Configuration/[Liunx]

[Liunx] Crontab 명령어사용법 - 정기적으로 스케줄러 실행하기

크론탭이란?

특정 시간에 프로그램을 실행시키기 위해 사용하며, 윈도우 스케줄러와 비슷한 기능을 한다.

매일 혹은 정기적으로 실행해야 하는 예약작업이 있다.
리눅스에서는 이런 일을 해 주는 것이 cron이다.
cron은 간단한 텍스트 파일에 할 일들을 기록하는데, 관리자인가 아닌가에 따라서 기록할 곳이 달라진다.

  • 관리자 권한이 있다면 /etc/crontab 파일에 기록한다.
  • 이 파일에 기록하면 한 눈에 예약 작업을 확인할 수 있다는 장점이 있고, 명령을 실행할 사용자도 명시할 수 있다. 
  • 관리자 권한이 없다면 crontab -e 명령어를 실행해서 예약 파일을 편집한다.
  • /etc/crontab 파일을 편집할 때와 달리 실행할 주체를 명시하는 부분이 없다.

 

root 권한 있는 경우 - /etc/crontab 편집

root 권한이 있는 경우 /etc/crontab 파일을 편집한다.
sudo vi /etc/crontab

# /etc/crontab: system-wide crontab
# Unlike any other crontab you don't have to run the `crontab'
# command to install the new version when you edit this file
# and files in /etc/cron.d. These files also have username fields,
# that none of the other crontabs do.

SHELL=/bin/sh
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin

# m h dom mon dow user command
17 * * * * root cd / && run-parts --report /etc/cron.hourly
25 6 * * * root test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.daily )
47 6 * * 7 root test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.weekly )
52 6 1 * * root test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.monthly )

맨 위에 주석으로 설명이 달려 있다.
“시스템 전반에 관여하는 크론탭이다. 다른 크론탭과 달리 사용자명을 적는 필드가 있다.”
SHELL은 cron을 실행할 쉘을 적어 주는 부분이고, PATH는 cron을 실행할 때의 $PATH다

사용자의 것과 다르니 유의
맨 밑의 4줄이 예약 작업 규칙과 명령어를 적어 주는 부분이다. 탭 혹은 띄어쓰기로 구분한다. 밑에서부터 5번째줄을 보면 각 열의 의미를 설명한 주석이 보인다:
# m h dom mon dow user command

  • 맨 앞의 다섯 열이 실행 시간 규칙을 적는 부분
  • 그 다음이 실행할 사용자를 적는 부분
  • 그리고 그 다음이 실행할 명령어를 적는 부분이다.

 

root 권한 없는 경우 - crontab -e

root 권한이 없는 경우에는 crontab -e를 실행한다.
환경변수에 에디터가 설정돼 있지 않으면 어떤 에디터를 쓸 거냐고 묻기도 한다.
nano를 추천한다고 씌어 있다. 터미널 에디터에 익숙지 않다면 나노를 사용하자.

나노는 저장하고 종료하려면 ctrl-x를 누른다. 변경사항이 있으면 저장할 거냐고 묻는데 y라고 쓰고 엔터치면 된다.
우분투의 경우 crontab -e로 처음 들어가면 기본 설정이 나온다. 아무 예약 작업도 없고, 주석만 있다.

맨 아랫줄을 보면 m h dom mon dow command 하고 각 열을 설명하는 주석이 있는데,
/etc/crontab과 달리 username 열이 없다.

 

크론탭 (Crontab) 옵션

crontab -l : 예약된 작업리스트
crontab -e : 예약된 작업 수정
crontab -r : 예약된 작업 삭제
crontab -u 사용자명 : 루트관리자는 해당 사용자 crontab 파일을 보거나 삭제, 편집 가능

 

특수문자

  •  *  : 모든 값을 뜻합니다.
  •  ?  : 특정한 값이 없음을 뜻합니다. 
  •  -  : 범위를 뜻합니다. (예) 월요일에서 수요일까지는 MON-WED로 표현
  •  ,  : 특별한 값일 때만 동작 (예) 월,수,금 MON,WED,FRI 
  •  /  : 시작시간 / 단위  (예) 0분부터 매 5분 0/5
  •  L  : 일에서 사용하면 마지막 일, 요일에서는 마지막 요일(토요일)
  •  W  : 가장 가까운 평일 (예) 15W는 15일에서 가장 가까운 평일 (월 ~ 금)을 찾음
  •  #  : 몇째주의 무슨 요일을 표현 (예) 3#2 : 2번째주 수요일

 

주기 설정

  • 공백(space)으로 5개 값을 구분하여 설정
  • 요일에서 0과 7은 일요일
  • 1이 월요일 ~ 6이 토요일
*      *       *      *       *
분(0-59)  시간(0-23)  일(1-31)  월(1-12)   요일(0-7)

 분(0~59)을 설정. *을 설정한 경우 1분 단위로 실행
 시간(0~23)을 설정. *을 설정한 경우 매시간 실행
 일(1~31)을 설정. *을 설정한 경우 매일 실행
 월(1~12)을 설정. *을 설정한 경우 매달 실행
 요일(0~7)을 설정. *을 설정한 경우 월요일부터 일요일까지 매일 실행

주기 설정 예시

# 매분 testfile.sh 실행
* * * * * /home/test/testfile.sh
# 특정 시간 실행
# 매주 금요일 오전 5시 45분에 testfile.sh 를 실행
45 5 * * 5 /home/test/testfile.sh
# 반복실행
# 매일 매시간 0분, 20분, 40분에 testfile.sh 를 실행
0,20,40 * * * * /home/test/testfile.sh
# 범위 실행
# 매일 1시 0분부터 30분까지 매분 testfile.sh 를 실행
0-30 1 * * * /home/test/testfile.sh
# 간격실행
# 매 10분마다 testfile.sh 를 실행
*/10 * * * * /home/test/testfile.sh
# 5일에서 6일까지 2시,3시,4시에 매 10분마다 testfile.sh 를 실행
*/10 2,3,4 5-6 * * /home/test/testfile.sh
예시 설명
* * * * * 매일 매분마다 실행
5 * * * * 매일 매시간 05분에 실행
*/5 * * * * 매일 5분마다 실행
*/10 * * * * 매일 10분마다 실행
0 18 * * * 매일 18시 00분에 실행
15 18 * * * 매일 18시 15분에 실행
* 1 * * * 매일 01시 00분 ~ 01시 59분 사이에 매분마다 실행
0 */1 * * * 매일 1시간 간격으로 실행
0 */12 * * * 매일 12시간마다 실행
0 6,12 * * * 매일 06시, 12시에 실행
5 3-5 * * * 매일 03시 ~ 05시 사이 매시간 10분에 실행
(03시 05분, 04시 05분, 05시 05분)
15 6 15 * * 매달 15일 06시 15분에 실행
30 3 1,15 * * 매달 1일과 15일 03시 30분에 실행
0 18 * * 1 매주 월요일 18시 00분에 실행
0 6,12 * * 0,3 수, 일요일마다 06시, 12시에 실행
0 21 * * 1-6 월 ~ 토 21시 00분에 실행
0 11 11 11 11 ? 11월 11일 11:11마다

(크론표현식 사이트) Cron Maker : http://www.cronmaker.com/

 

크론탭 로깅

 크론탭 해당 처리 내역에 대해 로그로 남기고 싶을 때

* * * * * /home/test/testfile.sh > /home/test/testfile.sh.log 2>&1

# 매분마다 testfile.sh.log 파일이 갱신
* * * * * /home/test/testfile.sh >> /home/test/testfile.sh.log 2>&1

# 계속 로그가 누적이 되는 것을 확인
# 로그가 과도하게 쌓이면 리눅스 퍼포먼스에 영향을 주므로 가끔씩 비워주거나 파일을 새로 만들어줄 필요

반대로 로그는 필요 없는 크론

* * * * * /home/test/testfile.sh > /dev/null 2>&1
# 로그 필요 없는 크론

 

크론탭 백업

크론탭 내용을 txt 파일로 만들어 저장

crontab -l > /home/bak/crontab_bak.txt
# 크론탭 내용을 txt 파일로 만들어 저장
59 23 * * * crontab -l > /home/bak/crontab_bak.txt

# 백업을 자동화
# 매일 오후 11시 59분에 크론탭을 백업해두는 크론

 

사용자와 명령어

/usr/local/bin/script.sh를 매분 실행하게 한다고 가정하자. /etc/crontab에 적는다면 아래처럼 적는다.
* * * * * www-data /usr/local/bin/script.sh

crontab -e로 적는다면 아래처럼 적는다.
* * * * * /usr/local/bin/script.sh
사용자를 명시했는지만 차이가 있다. crontab -e의 실행 사용자는 작성자 자신이 된다.

실행 로그는 어디서 볼 수 있을까?

cron이 실행되면 /var/log/syslog에 실행이 됐다고 남는다.

실행 결과의 출력값이 syslog에 기록되는 것은 아니다.
명령어 실행 결과를 리디렉트하지 않으면 cron은 결과를 메일로 보낸다.
서버에 메일 발송 시스템이 돼 있지 않다면 이메일 내용은 /var/mail/{사용자명} 파일에 기록되게 된다.