IT모아

crontab 설정 방법 본문

Oracle

crontab 설정 방법

아롱사태남 2014.05.30 18:44

사용형식

 

crontab [ -u 사용자 id ] 파일

 

crontab -l : 예약된 작업리스트

crontab -e : 예약된 작업 수정

crontab -r : 예약된 작업 삭제

 

crond 실행 확인

 

ps -ef | grep crond

 

crond 시작

/etc/rc.d/init.d/crond start{restart | stop}

 

일반 사용자에게 crontab 명령어 사용하도록 설정 허가

/etc/cron.allow 여기에 ID 등록

 

일반 사용자의 CRONTAB 명령어 사용을 제한하고자 한다면

/etc/cron.deny 에 ID 를 등록

즉,

/etc/cron.allow : 허용할 사용자 ID 목록

/etc/cron.deny :  거부할 사용자 ID 목록

 

cron.allow 파일이 있으면 이 파일에 들어있는 ID만 사용 가능

cron.deny 파일이 있으면 이 파일에 들어잇는ID는 사용 불가

 

따라서 cron.deny에 따라서 truefeel ID를 추가해주면 됩니다.

 

등록 내용 설정

" 분,시,일,월,요일, 실행명령" 순으로 설정

 

crontab 파일 형식

------    --------    ---------------------------------------

필    드    의    미     범위

------    --------    ---------------------------------------

첫번째    분             0-59

두번째    시             0-23

세번째    일             0-31

네번째    월             1-12

다섯번째 요일          0-7 (0 또는 7=일요일, 1=월, 2=화...)

여섯번째 명령어       실행할 명령을 한줄로 쓴다.

------    --------    ---------------------------------------

 

한 줄당 하나의 명령 (두줄로 나눠서 표시할 수 없음)

# 으로 시작하는 줄은 실행하지 않는다. (주석)

 

crontab -e 을 하면 vi 에디터가 나온다(환경변수 EDITOR에 따라 다른 에디터를 사용할 수 있다.)

 

crontab -e

-    /home 디렉토리를 /BACKUP/home 으로 백업해둠

-    30분, 새벽 4시와 낮 12시, 모든 일, 모든 월, 모든 요일

30 4,12 * * *  /usr/bin/rsync -avxH --delete /home /BACKUP/home  > /dev/null 2>&1

 

-   파일/디렉토리 퍼미션 설정

-   40분, 새벽 1시, 매주 일요일

40 1 **0 /root/bin/perm_set.sh  > /dev/null 2>&1

 

-    20분마다 실행

*/20 **** / shell/mrtg

 

위는 매일 4:30분과 12:30분에 rsync 명령을, 매주 일요일 1:40분에 perm_set.sh를 실행함을 의미한다

 

vi 에디터를 통해 설정을 하므로 중요한 몇 가지 에디터 사용법은 익혀야 한다.

 

------    ---------------------------------------------------------------

키           의미

------    ---------------------------------------------------------------

i             현재 칸에 글을 넣는다

o            다음줄에 글을 넣는다.

dd          한줄을 삭제한다.

:wq        저장하고 빠져나온다.

ESC       설정중에 명령어 모드(위의 i, o, dd 등을 사용할 수 있는 상태)로 빠져 나온다.

------    ---------------------------------------------------------------

 

 

 

설정 예

시간 설정에서 몇가지 의미있는 것들을 알아보자.

 

'*' 표시는 해당 필드의 모든 시간을 의미한다.

-    3,5,7 와 같이 콤마(,)로 구분하여 여러 시간대를 지정할 수 있다.

-    2-10와 같이 하이픈(-)으로 시간 범위도 지정할 수 있다.

-    2-10/3와 같이 하이픈(-)으로 시간 범위를 슬래쉬(/)로 시간 간격을 지정할 수 있다.

(2~10까지 3간격으로 즉, 3,6,9를 의미함)

 

 

예)

20 2 * * 6 명령어  --> 매주 토요일 새벽 2:20

0 4-6 * * * 명령어 --> 매일 오후 4,5,6시

5 */2 * * * 명령어 --> 매일 2시간 간겨그로 5분대에

15 1 1 * * 명령어 -->매월 1일 새벽 1:15

30 0 1 1,7 * 명령어 --> 1,7월 1일 새벽 0:30

 

 

 

'Oracle' 카테고리의 다른 글

오라클 NVL 이란?  (0) 2014.06.19
정렬시 null 값 위치 지정  (0) 2014.06.09
crontab 설정 방법  (0) 2014.05.30
REGEXP_REPLACE 정의 및 예제(활용법)  (0) 2014.05.29
오라클에서의 LIMIT절과 같은 기능!!!  (0) 2014.04.23
일별 데이터를 한개씩 추출!!  (0) 2014.04.22
0 Comments
댓글쓰기 폼