IT/OracleLinux-1Z0460

CronTab 사용법

알콩달콩아빠 2022. 5. 4. 19:18
728x90
반응형

# 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내의 파일을 삭제

 

728x90
반응형

'IT > OracleLinux-1Z0460' 카테고리의 다른 글

ip 주소 클래스  (0) 2022.05.09
CentOS network 설정  (0) 2022.05.04
CentOS 기본명렁어  (0) 2022.05.04
vi 명령어  (0) 2022.05.04
DUMA  (0) 2022.05.04