nc. tail 과 logrotate 를 이용한 외부에서 로그를 모니터링하는 방법
글쓴이: ironiris / 작성시간: 화, 2007/07/31 - 2:24오후
며칠전 nc로 로그파일을 계속 외부에서 보는 방법에 대해서 질문을 드렸다가
나름 편리한 형태로 구성을 해서 같이 공유하고자 합니다.
이 구성은 프로그래밍시 디버깅을 하거나 서버를 운영시 모니터링을 하는 용도로 사용하면 좋습니다.
요즘 대부분의 배포본은 logrotate, nc, tail 이 설치되어있어서 설치 방법은 생략합니다.
그럼 어떻게 구성하느냐...
1. 원하는 곳에 로그파일을 저장합니다.(/etc/logrotate.d/원하는파일명으로 저장)
/var/log/로그파일명 { rotate 7 # 7개의 파일을 로테이션한다. compress # gz으로 압축한다. daily # 날마다 로테이션한다. 7개의 파일을 로테이션하니 1주일치만 저장한다. create 0644 root root # 로그파일을 로테이션후 새로 생성되는 파일의 퍼미션과 소유주 지정 }
2. 로그파일을 외부에 쓰는 스크립트
#!/bin/bash while true do tail -s 1 -n 1 -F /var/log/로그파일명|nc -w 20 -l -p 3000 done
tail프로그램의 옵션중
-s 1 은 1초마다 확인해라.
-n 1 은 끝에 1줄만 출력해라.
-F 파일명 은 파일명의 파일이 바뀌더라도 파일명을 기준으로 변경사항을 체크해라.
nc 의 옵션중
-w 20 은 20초동안 접속이 없으면 종료해라.(이거 없으면 나중에 telnet 으로 접속시 그동안 쌓인 로그 데이터가 주르륵~나와서 난감해집니다.)
-l 듣기 모드로 작동해서(서버로 작동해라)
-p 3000 : 3000번 포트로 작동해라.
이상입니다. :)
다른 분들께 도움이 되시길 바라며... ^^;
Forums:
댓글 달기