cron 시스템

Programming/linux 2007.11.28 11:09
1. cron 시스템
ㅇ cron 시스템이란?

- 특정 작업을 정해진 시간에 주기적이고 반복적으로 실행하기 위한 데몬과 그 설정들
- cron시스템에는 시스템에서 기본적으로 사용하는 cron설정이 있으며, 이를 시스템크론이라고 함.
- cron시스템에는 root나 일반사용자가 자신의 cron설정을 직접하여 사용하는 사용자크론이 있음.

ㅇ cron에 관한 데몬과 파일들
- cron데몬파일 : /usr/sbin/crond
- cron데몬의 시작/종료/재시작 : /etc/rc.d/init.d/crond start/stop/restart
- crond 실행확인 : ps –ef | grep crond
- cron설정파일 : /etc/crontab
- 시스템크론 설정디렉토리 : /etc/cron.hourly, /etc/cron.daily, /etc/cron.weekly, /etc/cron.monthly
- 사용자크론 설정파일 : /var/spool/cron/* (사용자계정명과 동일한 파일명으로 존재함.)
- 사용자크론설정 명령어 : /usr/bin/crontab
- cron실행내용 기록되는 로그파일 : /var/log/cron
*참고 : atd에 의한 수행내역은 /var/log/messages에 기록됨.

사용자 삽입 이미지

2. cron의 실행주기 설정형식과 방법

ㅇ 시스템 cron설정의 예 (/etc/crontab파일의 일 부분)

[root@edu anacron]# cat /etc/crontab
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/
# run-parts
01 * * * * root run-parts /etc/cron.hourly
02 4 * * * root run-parts /etc/cron.daily
22 4 * * 0 root run-parts /etc/cron.weekly
42 4 1 * * root run-parts /etc/cron.monthly
[root@edu anacron]#

ㅇ 사용자 cron설정의 예 (root의 cron설정 예)

[root@edu anacron]# crontab -l
00 01 * * * su - root /usr/bin/rdate -s time.bora.net && /sbin/hwclock -w
00 03 * * * su - root '/root/backup.sh' >& /dev/null
00 08 * * * su - root '/root/check_of_system.sh' > /root/COS_result
[root@edu anacron]#

ㅇ 각 필드의 의미
사용자 삽입 이미지

ㅇ 참고1 : * 기호 : 각 필드자리에 * 기호가 오면 해당 필드의 모든 값을 의미함.
- 두번째 필드에 *가 오면 매시, 세번째 필드의 *는 매일, 네번째 필드의 *는 매월을 각각 의미함.
ㅇ 참고2 : - 기호 : 그 사이의 모든 값을 의미함.
- 예) 두번째 필드의 “5-9”는 5시,6시,7시,8시,9시를 의미함.
- 예) 세번째 필드에 “1-5”는 1일,2일,3일,4일,5일을 의미함.
ㅇ 참고3 : ,(콤마)기호 : 지정한 모든 값을 의미함.(불규칙적인 값 지정시 사용)
- 예) 두번째 필드에 “1,3,4,7,8”는 1시,3시,4시,7시,8시를 의미함.
- 예) 세번째 필드에 “1,5,20”는 1일, 5일, 20일을 의미함.

3. 시스템 cron의 이해와 활용

[root@edu /]# cat /etc/crontab
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/
# run-parts
01 * * * * root run-parts /etc/cron.hourly
02 4 * * * root run-parts /etc/cron.daily
22 4 * * 0 root run-parts /etc/cron.weekly
42 4 1 * * root run-parts /etc/cron.monthly
[root@edu /]#
[root@edu /]# ls -l /etc/cron.hourly/
total 0
[root@edu /]#
[root@edu /]# ls -l /etc/cron.daily/
lrwxrwxrwx 1 root root 28 Jan 23 01:30 00-logwatch -> ../log.d/scripts/logwatch.pl
-rwxr-xr-x 1 root root 135 Mar 4 2005 00webalizer
-rwxr-xr-x 1 root root 276 Mar 17 2005 0anacron
-rwxr-xr-x 1 root root 180 Apr 1 2005 logrotate
-rwxr-xr-x 1 root root 104 May 25 2005 rpm
-rwxr-xr-x 1 root root 246 Apr 17 2005 slocate.cron
-rwxr-xr-x 1 root root 158 May 26 2005 yum.cron
[root@edu /]#
[root@edu /]# ls -l /etc/cron.weekly/
-rwxr-xr-x 1 root root 277 Mar 17 2005 0anacron
-rwxr-xr-x 1 root root 414 Apr 8 2005 makewhatis.cron
-rwxr-xr-x 1 root root 90 May 26 2005 yum.cron
[root@edu /]#
[root@edu /]# ls -l /etc/cron.monthly/
-rwxr-xr-x 1 root root 278 Mar 17 2005 0anacron
[root@edu /]#

ㅇ 사용자 cron 의미
- 개별 사용자가 자신의 cron설정을 개별적으로 할 수 있음.
- 개별 사용자의 cron설정파일은 /var/spool/cron 디렉토리내에 자신의 ID와 동일한 파일로 생성됨
[root@edu /]# ls -l /var/spool/cron
total 16
-rw------- 1 root bible 60 Feb 15 13:07 bible
-rw------- 1 root root 195 Feb 15 12:44 root

ㅇ 사용자 cron 설정시 사용명령어(crontab)
- 개별사용자의 cron설정 방법 : crontab –e
- 개별사용자의 cron설정 확인 방법 : crontab –l
- 개별사용자의 cron설정 삭제 방법 : crontab –r
- root의 일반사용자 cron설정 방법 : crontab –u 사용자명 –e
- root의 일반사용자 cron설정 확인 방법 : crontab –u 사용자명 –l
- root의 일반사용자 cron설정 삭제 방법 : crontab –u 사용자 -r

ㅇ cron 사용허가(불허가) 설정파일
- /etc/cron.allow 파일 : 이 파일에 등록된 사용자는 crontab으로 cron설정가능함.
- /etc/cron.deny 파일 : 이 파일에 등록된 사용자는 crontab으로 cron설정 불가능함
- 설치초기 값으로는 이 두 파일은 존재하지 않음. 따라서 필요시 생성해야 함.
- 설정방법은 한 행에 하나의 ID씩 기재하면 됨.
- 두 파일이 모두 존재하지 않으면 root만 가능.
- 만약 /etc/cron.allow파일을 만들었다면 root라도 이 파일에 root를 등록해야 사용 가능함.

4. at 예약작업 스케줄링 활용

ㅇ 예약작업 스케줄링이란?

- 특정일, 지정된 시간에 정해진 작업을 1회 수행하도록 하는 것.
- 주기적, 반복적 수행을 하는 cron과는 그 성격이 다름.

ㅇ 예약작업 스케줄링에 사용되는 명령어
- 예약작업 수행 데몬 : atd
- 예약작업 설정 : at (또는 가끔씩 batch를 사용하기도 함.)
- 예약작업 확인 : at –l 또는 atq
- 예약작업 취소 : at –d 또는 atrm
- 예약작업 즉시 실행 : at –s 또는 atrun

ㅇ 예약작업 수행될 작업 목록 저장 위치 : /var/spool/at
ㅇ at로 예약작업을 수행할 수 있는 권한 설정파일 : /etc/at.allow, /etc/at.deny
- /etc/at.allow파일만 존재하면 이 파일에 설정된 사용자만 사용가능
- /etc/at.deny파일만 존재한다면 이 파일에 설정된 사용자외 모두 사용가능
- /etc/at.allow, /etc/at.deny 모두 존재하지 않는다면 root만 사용가능
- /etc/at.allow, /etc/at.deny 모두 존재하지만 내용이 모두 없다면 모든 사용자가 사용가능.
ㅇ atd데몬 시작/종료/재시작 : /etc/rc.d/init.d/atd start/stop/restart
ㅇ atd에 의해 수행된 로그기록 : /var/log/messages



위 내용은 ㈜수퍼유저코리아(www.superuser.co.kr)에 저작권이 있습니다.
원본 파일 : http://edu.phpschool.com/lecture/lec_linux_01/lec-data/10data.pdf
신고
크리에이티브 커먼즈 라이선스
Creative Commons License

'Programming > linux' 카테고리의 다른 글

linux 계정 lock 되는 현상.  (0) 2009.06.11
vsftpd ip 제한  (0) 2009.06.02
cron 시스템  (0) 2007.11.28
리눅스에서 svn설치  (0) 2007.11.28

리눅스에서 svn설치

Programming/linux 2007.11.28 10:46

1. 사용 할 각각의 파일들 구하기

위의 파일들을 /root에 받습니다.

 http://subversion.tigris.org/servlets/ProjectDocumentList?folderID=260&expandFolder=74

다운로드. subversion-1.4.4.tar.gz

  http://www.openssl.org/source 여기서 lastest

자~ 설치해보자.

2. OpenSSL 컴파일과 설치

 # tar vxzf openssl-0.9.7c.tar.gz
 # cd openssl-0.97c
 openssl-0.97c# ./config
 openssl-0.97c# make
 openssl-0.97c# make install

3 .Berkeley DB 컴파일과 설치

  # tar vxzf db-4.3.29.tar.gz
  # cd db-4.3.29
  db-4.3.29# cd build_unix
  db-4.3.29/build_unix# ../dist/configure
  db-4.3.29/build_unix# make
  db-4.3.29/build_unix# make install
  db-4.3.29/build_unix# echo "/usr/local/BerkeleyDB.4.3/lib" >> /etc/ld.so.conf
  db-4.3.29/build_unix# ldconfig  
 

4. Apache 컴파일과 설치

# tar vxzf httpd-2.0.59.tar.gz
httpd-2.0.59# ./configure --prefix=/usr/local/apache2 --enable-suexec \
                          --enable-so --with-suexec-caller=bin \
                          --enable-ssl --with-ssl=/usr/local/ssl --enable-cache \
                          --enable-ext-filter --with-z=/usr/include --enable-dav \
                          --with-dbm=db4 --with-berkeley-db=/usr/local/BerkeleyDB.4.2
httpd-2.0.59# make
httpd-2.0.59# make install

5. Subversion 컴파일과 설치

데비안의 경우 zlib1g-dev, libxml2-dev, libexpat1-dev의 패키지가 필요합니다. 다른 배포판의 경우도 거의 같은 이름으로된 패키지가 있을 것입니다. 이 패키지들은 라이브러리와 헤더 파일을 포함하고 있는 것들입니다.


앞에서 Apache를 설치했을 경우
# tar vxzf subversion-1.4.2.tar.gz
# tar vxzf subversion-deps-1.4.2.tar.gz
# cd subversion-1.4.2
subversion-1.4.2# ./configure --with-zlib
                           --with-apxs=/usr/local/apache2/bin/apxs \
                           --with-berkeley-db=/usr/local/BerkeleyDB.4.3
subversion-1.4.2# make
subversion-1.4.2# make install

Apache를 설치하지 않았을 경우
# tar vxzf subversion-1.4.2.tar.gz
# cd subversion-1.4.2
subversion-1.4.2# ./configure --with-zlib \
                              --with-berkeley-db=/usr/local/BerkeleyDB.4.3
subversion-1.4.2# make
subversion-1.4.2# make install












이 글은 스프링노트에서 작성되었습니다.

신고
크리에이티브 커먼즈 라이선스
Creative Commons License

'Programming > linux' 카테고리의 다른 글

linux 계정 lock 되는 현상.  (0) 2009.06.11
vsftpd ip 제한  (0) 2009.06.02
cron 시스템  (0) 2007.11.28
리눅스에서 svn설치  (0) 2007.11.28

Apache2와 Tomcat5 연동하기

Programming/Apache 2007.11.26 15:15

다른 참고 페이지 : http://php.chol.com/~vision82/tt/38



Apache2와 Tomcat5 연동하기

/*','[-]'); } /*]]>*/

작성자 : 박상현(브루펜시럽)

2006년 7월 9일 일요일 오전 5시즘 작성을 시작하였습니다. 기후는.. 제주도로 태풍이 북상중이라고 합니다.

1 서론


저는 사정상 PHP와 JSP 를 모두 처리해줄 필요가 있었기 때문에 Apache2/Tomcat5 연동 모델을 선택했습니다.

각자 처한 환경에 따라서 이 모델이 최선이 아닐 수도 있습니다. Tomcat5 의 standalone 모드도 고려해주시기 바랍니다. ^^

연동시 사용되는 connector 에는 mod_jserv, JK, JK2, mod_webapp or mod_proxy 등이 있습니다.

자세한 내막은 알지는 못하지만 jserv 와 mod_webapp 는 오래전부터 외면받아온 것 같고

JK2 는 개발자들의 흥미 부족을 이유로 개발이 중단되었습니다.

따라서 JK 와 mod_proxy 가 남는 데.. Apache2.2 부터는 mod_proxy_ajp 모듈이 제공됩니다.

국내에서는 해당 모듈을 이용한 연동 사례를 찾을 수 없어서 도전해보았습니다.


연동시 테스트된 환경은 다음과 같습니다.

OS Fedora core 5
Apache2.2 httpd-2.2.2-1.0
Tomcat5.5 tomcat5-5.5.15-1jpp_6fc
Java jdk 1.5.0_07

리눅스에 입문한지 얼마 안되어서 FC5 외의 환경에 대해서는 잘 알지 못하기 때문에

테스트에 사용된 설치 방법이 제공되지 않거나 적절하지 않을 수 있으며 언급된 경로등이 다를 수 있습니다.

find / -name {대상} 혹은 which {대상} 등으로 적절한 경로를 확인하시기 바랍니다.

2 Apache 2.2


  • yum 을 이용해서 관련 rpm 패키지들을 설치합니다.
# yum -y install httpd\*

  • httpd.conf 파일을 열어서 다음에 언급된 구문들을 찾아서 수정해줍니다.

    각 문구들이 의미하는 바에 대해서는 별도의 문서를 참고하여 주시기 바랍니다.

    제가 수정한 부분에 대해서만 언급하였습니다.
# vim /etc/httpd/conf/httpd.conf
서버관리자의 email 주소를 입력해줍니다. 에러페이지에 표시됩니다.
ServerAdmin root@localhost
주석을 풀어줍니다. 브라우저에서 http://127.0.0.1/~계정 으로 접속하면 /home/계정/public_html/ 에서 웹문서을 찾게 됩니다.
<IfModule mod_userdir.c>
    UserDir public_html
</IfModule>
언어별 우선 순위라고 합니다. ko 를 맨 앞으로 옮겨줍니다.
LanguagePriority ko en ca cs da de el eo es et fr he hr it ja ltz nl nn no pl pt pt-BR ru sv zh-CN zh-TW
UTF-8 을 사용하기엔 아직 환경이 충분히 조성되지 않은 것 같습니다. 인코딩 방식을 EUC-KR로 변경해줍니다.
AddDefaultCharset EUC-KR

  • 방화벽에서 80번 포트가 열렸는 지 확인합니다.
  • 아파치 데몬을 시작합니다.
# service httpd start

  • 브라우저에서 http://127.0.0.1/ 로 접속해봅니다. 참고로 페도라에서는 Fedora Core Test Page 가 떴습니다.
  • 아파치 데몬을 끝내려면 다음과 같이 입력합니다.
# service httpd stop

3 J2SE

Fedora core 5 에서는 JDK 5.0 을 rpm.bin 을 받아서 설치할 경우에 각종 경로 설정 문제가 발생하게 됩니다.

따라서 다음 싸이트에 나와있는 방법을 사용했습니다. http://www.fedorafaq.org/#java

그 외의 환경에서는 JavaInstallation 에 나와있는 설치 방법을 따르시기 바랍니다.


# yum -y install rpm-build

  • 다운 받은 JDK 파일을 빌드를 위해서 source 디렉토리로 이동 시킵니다.
# mv jdk-1_5_0_07-linux-i586-rpm.bin /usr/src/redhat/SOURCES/

# rpmbuild --rebuild java-1.5.0-sun-1.5.0.07-1jpp.nosrc.rpm
꽤 오래 작업합니다. 커피 드시면서 기다립니다.

  • 빌드된 rpm 을 설치합니다.
# yum -y localinstall /usr/src/redhat/RPMS/i586/java-1.5.0-sun-*
제 경우에는 nosigned 메시지와 함께 설치가 되지 않았습니다. 이 경우에는 rpm -Uvh 로 설치해주면 됩니다.

설치하는 패키지 중에 unixODBC-devel 패키지에 의존성이 있는 패키지가 있으니 먼저 설치해줍니다.
# yum -y install unixODBC-devel
# rpm -Uvh ~~ 

  • 설치가 정상적으로 되었는 지 확인해봅니다.
# java -version
java version "1.5.0_07" 과 같이 나오면 성공입니다.

만약 1.4.2 버전으로 나온다면 alternatives 에서 java 가 manual mode로 1.4.2 버전 디렉토리를 링크로 삼고 있을 수 있습니다.

다음과 같이 입력하시거나
# alternatives --auto java
다음과 같이 입력한 후에 1.5.0 버전 경로를 선택해주시면 됩니다.
# alternatives --confige java

4 Tomcat 5.5

  • yum 을 이용해서 관련 rpm 패키지들을 설치합니다.
# yum -y install tomcat5\*

  • 방화벽에서 8080포트를 열어줍니다.
  • 다음 파일을 수정합니다.
# vim /usr/share/tomcat5/bin/relink 
이 구문을 찾아서 -type d 옵션을 뒷편으로 옮겨준다.

find /var/lib/tomcat5/webapps -type d -mindepth 1 -maxdepth 2
find /var/lib/tomcat5/webapps -mindepth 1 -maxdepth 2 -type d

  • 다음 파일을 수정합니다.
# vim /usr/share/tomcat5/conf/workers.properties
#workers.tomcat_home=/var/tomcat
workers.tomcat_home=/usr/share/tomcat5

#workers.java_home=/opt/IBMJava2-13
workers.java_home=/usr/lib/jvm/java

  • tomcat5 admin툴에서 사용되는 계정 정보가 담겨 있습니다. 수정해줍니다. ( adminpassword 부분은 원하시는 패스워드를 입력하세요. )
# vim /usr/share/tomcat5/conf/tomcat-users.xml
<?xml version='1.0' encoding='utf-8'?>
<tomcat-users>
  <role rolename="tomcat"/>
  <role rolename="manager"/>
  <role rolename="admin"/>
  <user username="admin" password="adminpassword" roles="admin,manager,tomcat"/>
</tomcat-users>

  • 사용자 계정을 지원하기 위하여 수정해줍니다.
# vim /usr/share/tomcat5/conf/server.xml
<Host name="localhost" ...>
  ...
  <Listener className="org.apache.catalina.startup.UserConfig"
            directoryName="public_html"
            userClass="org.apache.catalina.startup.PasswdUserDatabase"/>
  ...
</Host>
적절한 호스트 아래에 다음의 Listener를 추가하게 되면 /etc/passwd 파일을 참고로 해서

http://127.0.0.1:8080/~user_account 로 들어온 접속을 /home/user_account/public_html 로 연결하여 준다고 합니다.


  • tomcat을 실행합니다.
# service tomcat5 start
브라우저에서 http://127.0.0.1:8080/로 접속해봅니다. 고양이가 나타나면 OK.

  • 이제 tomcat을 종료시킵니다.
# service tomcat5 stop

5 mod_proxy_ajp

mod_proxy_ajp.conf 에 기술된 mod_proxy_ajp 을 이용하는 방법은

다음과 같이 설정하여 줌으로서 특정 URL로 들어온 요청은 전부 톰캣이 처리하게 하는 것입니다.
ProxyPass /tomcat/ ajp://localhost:8009/
이 경우에는 jsp나 서블릿과 html 문서와 이미지등을 서로 경로를 구분해서 저장해야 본래의 목적을 달성할 수 있다는 문제점이 있습니다.

따라서 mod_rewirte 를 이용해서 .jsp 파일만 톰캣이 처리하는 방법을 사용하였습니다.

  • proxy_ajp.conf 파일을 열어서 다음과 같이 추가해줍니다.
# vim /etc/httpd/conf.d/proxy_ajp.conf
RewriteEngine On
#RewriteLog /root/mod_proxy_ajp.txt
#RewriteLogLevel 9
RewriteCond %{REQUEST_FILENAME} .jsp
RewriteRule (.*) ajp://localhost:8009$1 [P]

  • Tomcat5 의 홈디렉토리를 /var/www 로 변경해줍니다.
# cd /usr/share/tomcat5/webapps/ROOT
# mv ROOT ROOT.old
# ln -s /var/www/html /usr/share/tomcat5/webapps/ROOT
# cp -r /usr/share/tomcat5/webapps/ROOT.old/WEB-INF/ /usr/share/tomcat5/webapps/ROOT/WEB-INF

  • 아파치 데몬을 실행합니다.
# service httpd start

  • tomcat 을 실행합니다.
# service tomcat5 start

  • 테스트용으로 test.jsp 파일을 작성합니다.
# vim /var/www/html/test.jsp
<%@ page contentType="text/html; Charset=EUC-KR" %>
<%
out.println("Hello");
%>

6 기타 사항

페도라에서 service 명령어를 인식 못할 때는

일반 계정에서 root 계정으로 넘어갈 때 su 라고만 쳐줘서 /sbin 디렉토리가 PATH 에 추가되지 않은 경우일 수도 있습니다.
# . /etc/profile
하시면 PATH 가 적절하게 갱신되며 service 명령어가 제대로 인식될 것입니다. 다음부터는 su - 라고 입력하시는 게 바람직합니다.

뭐 제가 잘 몰라서 그랬습니다. 흐늘흐늘

7 참고 사이트

아래의 문서들 덕분에 무사히 항해를 마치고 라꾸라꾸 속으로 들어가봅니다. 감사합니다.

8 피드백

뭐라도 괜찮으니 한마디씩 써주고 가세요. ;ㅁ;

음 굿 ㅋ? -- ddakker

잘 읽고 갑니다. 수고에 감사드립니다. :-) -- allieus

이 글은 스프링노트에서 작성되었습니다.

신고
크리에이티브 커먼즈 라이선스
Creative Commons License

'Programming > Apache' 카테고리의 다른 글

Apache-Tomcat proxy ajp  (0) 2012.02.08
[scrap]compile mod_proxy to existing apache (cpanel can do)  (0) 2009.06.04
Apache Tomcat Context 설정  (0) 2007.12.21
Apache2와 Tomcat5 연동하기  (0) 2007.11.26


티스토리 툴바