서버 모니터링 · 3 min read · Oct 16, 2025
CentOS 5.2에서 munin 및 monit로 서버 모니터링 - 2페이지
5 monit 설치 및 구성
다음으로 monit를 설치합니다:
yum install monit그런 다음 monit의 시스템 시작 링크를 생성합니다:
chkconfig --levels 235 monit onmonit의 기본 구성 파일은 /etc/monit.conf이며, 여기에서 몇 가지 구성 예제를 찾을 수 있습니다 (http://mmonit.com/wiki/Monit/ConfigurationExamples에서 더 많은 구성 예제를 찾을 수 있습니다) 모두 주석 처리되어 있지만, monit에게 /etc/monit.d 디렉토리에서도 구성 파일을 찾도록 지시합니다. 따라서 /etc/monit.conf를 수정하는 대신 새로운 구성 파일 /etc/monit.d/monitrc를 생성합니다. 제 경우에는 proftpd, sshd, mysql, apache 및 postfix를 모니터링하고 싶으며, 포트 2812에서 monit 웹 인터페이스를 활성화하고 싶고, https 웹 인터페이스를 원하며, 웹 인터페이스에 admin 사용자 이름과 test 비밀번호로 로그인하고 싶고, monit가 root@localhost로 이메일 알림을 보내도록 하고 싶습니다. 그래서 제 파일은 다음과 같습니다:
vi /etc/monit.d/monitrc| set daemon 60 set logfile syslog facility log_daemon set mailserver localhost set mail-format { from: [email protected] } set alert root@localhost set httpd port 2812 and SSL ENABLE PEMFILE /var/certs/monit.pem allow admin:test check process proftpd with pidfile /var/run/proftpd.pid start program = "/etc/init.d/proftpd start" stop program = "/etc/init.d/proftpd stop" if failed port 21 protocol ftp then restart if 5 restarts within 5 cycles then timeout check process sshd with pidfile /var/run/sshd.pid start program "/etc/init.d/sshd start" stop program "/etc/init.d/sshd stop" if failed port 22 protocol ssh then restart if 5 restarts within 5 cycles then timeout check process mysql with pidfile /var/run/mysqld/mysqld.pid group database start program = "/etc/init.d/mysqld start" stop program = "/etc/init.d/mysqld stop" if failed host 127.0.0.1 port 3306 then restart if 5 restarts within 5 cycles then timeout check process apache with pidfile /var/run/httpd.pid group www start program = "/etc/init.d/httpd start" stop program = "/etc/init.d/httpd stop" if failed host www.example.com port 80 protocol http and request "/monit/token" then restart if cpu is greater than 60% for 2 cycles then alert if cpu > 80% for 5 cycles then restart if totalmem > 500 MB for 5 cycles then restart if children > 250 then restart if loadavg(5min) greater than 10 for 8 cycles then stop if 3 restarts within 5 cycles then timeout check process postfix with pidfile /var/spool/postfix/pid/master.pid group mail start program = "/etc/init.d/postfix start" stop program = "/etc/init.d/postfix stop" if failed port 25 protocol smtp then restart if 5 restarts within 5 cycles then timeout |
(서버에 실제로 존재하는 프로세스만 확인하도록 하십시오 - 그렇지 않으면 monit가 시작되지 않습니다. 즉, monit에게 Postfix를 확인하도록 지시하지만 시스템에 Postfix가 설치되어 있지 않으면 monit가 시작되지 않습니다.)
구성 파일은 상당히 자명합니다; 옵션에 대해 확실하지 않은 경우 monit 문서를 참조하십시오: http://mmonit.com/monit/documentation/monit.html
monit 구성의 apache 부분에서 다음을 찾을 수 있습니다:
| if failed host www.example.com port 80 protocol http and request "/monit/token" then restart |
이는 monit가 www.example.com의 포트 80에 연결을 시도하고 /monit/token 파일에 접근하려고 시도한다는 것을 의미합니다. 이는 /var/www/www.example.com/web/monit/token입니다. 우리의 웹 사이트의 문서 루트가 /var/www/www.example.com/web이기 때문입니다. monit가 성공하지 못하면 Apache가 실행되고 있지 않다는 의미이며, monit는 이를 재시작할 것입니다. 이제 /var/www/www.example.com/web/monit/token 파일을 생성하고 그 안에 임의의 문자열을 작성해야 합니다:
mkdir /var/www/www.example.com/web/monit
echo "hello" > /var/www/www.example.com/web/monit/token다음으로 SSL 암호화된 monit 웹 인터페이스에 필요한 pem 인증서 (/var/certs/monit.pem)를 생성합니다:
mkdir /var/certs
cd /var/certs인증서를 생성하기 위해 OpenSSL 구성 파일이 필요합니다. 다음과 같이 보일 수 있습니다:
vi /var/certs/monit.cnf| # create RSA certs - Server RANDFILE = ./openssl.rnd [ req ] default_bits = 1024 encrypt_key = yes distinguished_name = req_dn x509_extensions = cert_type [ req_dn ] countryName = Country Name (2 letter code) countryName_default = MO stateOrProvinceName = State or Province Name (full name) stateOrProvinceName_default = Monitoria localityName = Locality Name (eg, city) localityName_default = Monittown organizationName = Organization Name (eg, company) organizationName_default = Monit Inc. organizationalUnitName = Organizational Unit Name (eg, section) organizationalUnitName_default = Dept. of Monitoring Technologies commonName = Common Name (FQDN of your server) commonName_default = server.monit.mo emailAddress = Email Address emailAddress_default = [email protected] [ cert_type ] nsCertType = server |
이제 다음과 같이 인증서를 생성합니다:
openssl req -new -x509 -days 365 -nodes -config ./monit.cnf -out /var/certs/monit.pem -keyout /var/certs/monit.pemopenssl gendh 512 >> /var/certs/monit.pemopenssl x509 -subject -dates -fingerprint -noout -in /var/certs/monit.pemchmod 700 /var/certs/monit.pem마지막으로 monit를 시작할 수 있습니다:
/etc/init.d/monit start이제 브라우저를 https://www.example.com:2812/로 이동시키고 (포트 2812가 방화벽에 의해 차단되지 않았는지 확인하십시오), admin과 test로 로그인하면 monit 웹 인터페이스를 볼 수 있습니다. 다음과 같이 보여야 합니다:

(메인 화면)

(Apache 상태 페이지)
/etc/monit.d/monitrc의 구성에 따라 monit는 서비스가 실패할 경우 서비스를 재시작하고 서비스의 프로세스 ID가 변경되면 알림 이메일을 보냅니다.
즐기세요!
6 링크
- munin: http://munin.projects.linpro.no
- monit: http://mmonit.com/monit
- CentOS: http://www.centos.org
- RPMforge: https://rpmrepo.org/RPMforge
새 게시물을 받은 편지함에서 받기
스팸은 없습니다. 언제든지 구독 해지 가능합니다.