Cron/ko

이 글은 젠투 리눅스의 크론 설치 및 사용법을 설명합니다.

크론이 하는 일
크론은 에 입력한 명령을 기반으로 하여 일정에 따라 계획한 작업을 실행하는 데몬입니다. 각 시간마다 작업을 실행하며 사용자 크론탭을 실행할 크론 작업이 있는지 살펴보는 역할을 합니다.

사실상 표준이나 다름 없는 크론
There are a few cron implementations to choose from in Portage. All of them offer a similar interface, namely the use of crontab or a similar command. There is also a related utility called Anacron which is meant to work with cron on systems that are not continuously running.

에 따라 존재하는 모든 크론 패키지를 참고할 만 합니다. 언급한 패키지는 다른 어떤 크론 패키지에 기술적으로 의존하는건 아니지만, 대부분의 사용자가 만족할 수 있는 크론 같은 기능을 제공합니다.

Before getting started working with cron, a proper cron implementation has to be selected. In this article information is provided for each cron implementation available in Gentoo Linux.

vixie-cron
빅시 크론(Vixie-cron)은 SysV 크론 기반으로 완전한 기능을 갖춘 구현체입니다. 각각의 사용자는 자신의 크론탭을 지니고 있으며, 크론탭에 환경 변수를 지정할 수 있습니다. 다른 크론 변형과는 달리, SELinux와 PAM을 지원합니다. Dcron과는 적은 일부 아키텍처만 지원하지만, Fcron보다는 많이 지원합니다.

의 기능은 다음과 같습니다:


 * SELinux 지원
 * PAM 지원
 * 크론탭에서의 환경변수 설정 (PATH, SHELL, HOME 등)
 * 각각의 사용자가 크론탭을 보유할 수 있음. 와 에서 접근 권한을 다룹니다.

cronie
Cronie is a fork of vixie-cron done by Fedora. Because of it being a fork it has the same feature set the original vixie-cron provides. Additionally cronie comes with an anacron implementation which must be enabled through the  USE flag.

dcron (Dillon's Cron)
Dcron aims to be a simple, elegant and secure implementation of cron. It does not allow the specification of environment variables in crontabs and all cron-jobs are run from. Like vixie-cron, each user has his own crontab.

의 기능은 다음과 같습니다:


 * Fast, simple and free of unnecessary features;
 * Access to crontab is limited to the cron group, i.e. it doesn't rely on any external faculties.

fcron
fcron은 빅시 크론과 아나크론을 대체하는것이 목표입니다. 지속적으로 동작하지 않는 시스템에서 동작하도록 설쳬했으며 추가 기능을 포함했습니다. 작업 시작 강제, 작업 직렬화 관리, 작업에 적절한 값 할당, 시스템 시작히 실행할 작업 배치 능력을 보유하고 있습니다. 더 알아보시려면 fcron's 홈페이지를 보십시오.

의 기능은 다음과 같습니다:


 * Designed to work on systems that are not continuously running, i.e. it can run a job after restarting if it was missed;
 * Setting of environment variables and many other options in crontabs;
 * Enhanced crontab syntax with support for many new features;
 * Each user can have a personal crontab, access is controlled by and

bcron
bcron은 안전한 동작을 개념으로 하여 설계한 새로운 크론 시스템입니다. 이를 실행하려면 시스템은 몇가지로 나누어 놓은 프로그램으로 쪼개져야 하는데, 각각의 프로그램은 서로간의 통신을 엄격하게 관리하면서 각자 맏은 작업을 처리해야 합니다. 사용자 인터페이스는 비슷한 체계 의 기능을 대체하지만, 내부적으론 상당히 다릅니다. http://untroubled.org/bcron 홈페이지를 살펴보십시오.

의 기능은 다음과 같습니다:


 * Drop-in replacement for vixie-cron;
 * Multiprocess design;
 * Native daylight savings time support.

아나크론
아나크론(Anacron)은 크론 데몬이 아니고 크론과 같이 동작하는 프로그램입니다. 지정한 날짜 간격대로 명령을 실행하며 시스템이 계속 동작함을 고려하진 않습니다. 시스템이 멈추었을때 놓친 작업을 실행합니다. 아나크론은 보통 각각의 날짜별로 실행할 크론 데몬과 관련이 있습니다.

설치
Select the right cron implementation for the job, and then emerge it:

Make sure the cron daemon of choice has been added to the system's init process; without this step the cron daemon will not perform its job.

Optionally, if Fcron has not been installed, installing Anacron as a helper to the cron daemon might be a wise choice.

Again, do not forget to add anacron to the system's init process.

시스템 크론탭
The post install messages from some of these cron packages instruct the user to run crontab /etc/crontab. The file is the system crontab. A cron installation can use it in conjunction with to run the scripts in. Note that only vixie-cron and cronie schedule jobs in automatically. Dcron and fcron users will need to run crontab /etc/crontab every time they make changes to the file.

Please note that jobs scheduled in the system crontab might not show up in the list of cron-jobs displayed by running crontab -l.

Of course, users can choose not to use any system crontab at all. If dcron or fcron has been chosen, do not run crontab /etc/crontab. If vixie-cron, cronie or bcron has been chosen comment all lines in.

A quick and easy way to comment out all the lines in a file is by using the sed command. Run the following command to comment out all the lines in

신뢰하는 사용자에게 크론 접근 권한 부여하기
For users other than root to have access to the cron daemon, read this section, otherwise proceed to the next section: Scheduling cron-jobs.

No matter which cron package has been chosen, to allow a user to use crontab he will first have to be in the cron group. As an example, to add the user wepy to the cron group run:

When using dcron, the above step is all that is needed to give a user access to crontab. Dcron users may proceed to the next section Scheduling cron-jobs, all others need to keep reading.

When using fcron, edit the and  files. The most secure way to run a system is to first deny all users in, and then explicitly allow users in.

If a user (wepy again for this example) should be able to schedule his own cron-jobs, then add him to as follows:

If vixie-cron or cronie has been chosen, then simply edit the file.

예컨대, "wepy" 사용자 접근을 허락하려면 다음과 같이 파일에 추가하십시오:

/etc/cron.allow 권한

크론 작업 일정 설정
크론탭 편집 과정은 꾸러미마다 다르지만 지원하는 명령 기본 모음은 같습니다. 크론탭을 추가하고, 내용을 바꾸고, 편집하고, 삭제하며, 크론탭의 항목을 조회합니다. 다음 목록엔 각 꾸러미에 대한 다양한 명령을 어떻게 실행하는지 보여줍니다.

이 명령을 사용할 수 있기 전에 먼저 크론탭 자체를 이해해야 합니다. 크론탭의 각 줄은 다음 순서로 다섯개의 시간 값을 지정합니다. 분(0-59), 시(0-23), 월 중 일수(1-31), 월(1-12), 주중 일수(0-7, 월요일은 1, 토요일은 7). 주중 일수와 월중 일수는 mon, tue, jan, feb 등의 세글자 약자로 지정할 수 있습니다. 또한 값의 범위(1-5 또는 mon-fri) 또는 쉼표 구분 값(1,2,3 또는 mon,tue,wed), "단계"값을 병기한 범위값 표기식(1-6/2는 1, 3, 5와 같음)으로 지정할 수 있습니다.

얘기가 조금 혼동스럽지만, 몇가지 예제를 통해, 말씀드린대로 그다지 복잡하지 않음을 이해할 수 있습니다.

다른 내용을 시험해보기 위해 몇가지 크론 작업을 실제로 입력하는 단계를 진행해보도록 하겠습니다. 먼저, 파일을 만드시고 다음과 같이 내용을 입력하십시오:

이제 위 표에 주어진 "새로 만들기 명령"으로 시스템의 크론탭에 추가하십시오.

계획한 크론 작업을 검증하려면 위의 표에 있는 적당한 목록 출력 명령을 사용하십시오.

파일과 닮은 목록을 봐야 하는데, 목록이 나타나지 않으면 크론탭에 입력할 명령을 잘못 실행했을 수도 있습니다.

이 크론탭은 echo "I really like cron" 명령을 매분 매시간 매일 매달마다 실행합니다. 확실히 사용자는 cron이 좋을 때만 그렇게 해야 합니다. 또한 echo "I like cron a little" 명령을 1월과 2월에 매일 16:30에 실행합니다. echo "I don't really like cron" 명령을 1월 1일 3:10에 실행하기도 합니다.

아나크론을 사용한다면, 이 장을 계속 읽어내려가야 합니다. 그렇지 않으면, 다음장 크론탭 편집으로 내용 읽기를 진행하십시오.

아나크론 사용자는 파일을 편집하려 할 것입니다. 이 파일은 매 실행 일자 간격, 실행 후 지연 시간, 작업 이름, 실행할 명령 네가지 내용으로 구성되어 있습니다.

예를 들어 명령을 5일마다 아나크론 시작 10분 후에 실행한다면 다음과 같이 적으십시오:

아나크론은 작업을 모두 끝난 다음에 빠뎌나갑니다. 매일 실행해야 하는 작업을 확인할 용도로 크론 데몬을 사용합니다. 다음 장의 마지막 부분에서 이 절차를 어떻게 다루는지 설명하겠습니다.

크론탭 편집
Being realistic, no user would want their system telling them how much they like cron every minute. As a step forward, remove the previous example crontab using the corresponding remove command from the table above. Use the corresponding list command to view the cron-jobs afterward to make sure it worked.

No cron-jobs should be displayed in the output from crontab -l. If cron jobs are listed, then the remove command failed to remove the crontab; verify the correct remove command for the system's cron package.

Now that we have a clean state, let's put something useful into the root crontab. Most people will want to run updatedb on a weekly basis to make sure that mlocate works properly. To add that to the system's crontab, first edit again so that it looks like the following:

위 항목은 updatedb를 매주 월요일 새벽 2시 22분에 실행합니다. 위 표를 통해 적당한 "새로 만들기 명령"으로 크론탭에 입력하고 목록을 확인하십시오.

이제, 여러분이 매일 포티지 트리를 최신으로 유지하려 매일 실행할 명령을 추가해보겠습니다. 먼저 파일을 열고, 앞에서 했던 것처럼  명령을 사용하거나, 앞서 표에서 언급했던 적당한 편집 명령을 사용할 수 있습니다. 이렇게 하면, 파일 같은 외부 파일에 의존하지 않고도 이런 상황에서 사용자 크론탭을 편집할 수 있습니다.

The above command should open the user's crontab with an editor. For example, if emerge --sync</tt> is to be run every day at 6:30 A.M., make the crontab look something like this:

22 2 * * 1  /usr/bin/updatedb 30 6 * * *   /usr/bin/emerge --sync 30 7 * * *   /usr/sbin/anacron -s
 * 1) (if you're using anacron, add this line)

Again, check the cron-jobs list as done in the previous examples to make sure the jobs are scheduled. If they are all there, then the system is ready to rock and roll.

크론 베이스 사용
앞에서 보신 바와 같이, 존재하는 모든 크론 꾸러미는 에 의존합니다. 크론 베이스 패키지는 를 만들고 스크립트는 를 호출합니다. 다음과 같은 내용이 있는 기본 파일을 보겠습니다:

0 *  * * *      rm -f /var/spool/cron/lastrun/cron.hourly 0 3  * * *      rm -f /var/spool/cron/lastrun/cron.daily 15 4 * * 6      rm -f /var/spool/cron/lastrun/cron.weekly 30 5 1 * *      rm -f /var/spool/cron/lastrun/cron.monthly
 * /15 * * * *   test -x /usr/sbin/run-crons && /usr/sbin/run-crons

너무 자세한 내용 진행을 막기 위해, 그냥 명령 하나가 시간별, 일자별, 주별, 월별 스크립트로 동작함을 가정할 수 있습니다. 이런 크론 작업 일정 계획 방식은 몇가지 중요한 장점이 있습니다:


 * 실행하기로 되어 있을때 전원이 꺼져도 실행합니다
 * 꾸러미 관리자가 제대로 정의한 위치에 스크립트를 쉽게 놓을 수 있습니다
 * 관리자는 크론 작업과 크론 탭을 저장하는 위치를 정확히 알며, 이 덕분에 시스템의 이 언급한 부분을 백업하고 복구하기 쉽습니다

아나크론 사용
앞서 이야기한 바와 같이 시스템에서 사용하는 아나크론은 지속적으로 (데스크톱 설치처럼) 실행함을 의미하는 것은 아닙니다. 기본 설정 파일은 보통 다음과 같습니다:

이 부분과 다른 크론탭과의 주된 차이점은, 작업 일정 계획에 정해진 날짜와 시간이 없지만 실행 주기는 존재합니다. 아나크론을 시작하면 파일 내용을 확인하고 설정 파일의 관련 항목이 마지막으로 실행한 후 유효기간을 경과 했는지 계산합니다. 만약 그런 작업이 있다면 명령을 다시 실행합니다.

마지막 참고할 사항으로, 다음 vixie-crom 크론탭 예제에서와 같이 시스템에 설치한 다른 크론의 중복 적용 항목을 주석처리하는것이 매우 중요합니다.

이 동작을 처리하지 않으면, 일일, 주간, 월간 부분의 각기 다른 부분을 - 각자 다른 시간에 - 크론 데몬과 아나크론이 실행하여 작업을 두번 실행하도록 유발합니다.

마지막 참고
각각의 크론 꾸러미는 다르며 기능 범위도 확연히 차이가 있음을 기억해두십시오. 꾸러미를 사용중인 크론 데몬에 따라 crontab, fcrontab, anacrontab에 대한 맨 페이지를 살펴보십시오.

행운을 빕니다 :-P !

문제 해결
When having problems getting cron to work properly, this quick checklist might be helpful.

크론이 실행하는 중인가요?
크론이 동작중인지 활용하려면 프로세스 목록에 나타나는지 확인하십시오:

크론이 동작중인가요?
다음 명령을 실행해보세요:

다음 이 주기적으로 바뀌는지 확인해보세요.

명령이 동작하나요?
이전과 마찬가지지만, 표준 오류 출력을 있는 그대로 리다리렉트 해야 합니다:

Can cron run the job?
보통 에서, 오류 내용은 에서 크론 로그를 확인해보세요.

가 있나요?
cron usually sends mail when there is a problem; check for mail and look for the creation of a file.

대응 크론 프로그램
일부 호스팅 회사에서는 크론 접근을 허용하지 않지만, 무료 또는 상업용으로 사용할 수 있는 대응 크론 작업 프로그램이 있습니다:


 * EasyCron