Monit installieren: Unterschied zwischen den Versionen
Zeile 43: | Zeile 43: | ||
[[Kategorie:Installationsanleitungen]] | [[Kategorie:Installationsanleitungen]] | ||
[[Kategorie:eigene Daemons]] | [[Kategorie:eigene Daemons]] | ||
== Logfiles kontrollieren == | |||
Monit loggt entsprechend der Konfiguration seine "Taten" in ~/var/monit.log | |||
Damit das Logfile nicht zu groß wird, benutzen wir '''logrotate''', das von [[cron]] aufgerufen, einmal pro Woche das Logfile komprimiert und zwei alte Versionen hält. Dazu erstellen wir die Konfigdatei .logrotate im Hauptverzeichnis des Users: | |||
touch .logrotate | |||
Darin schreiben wir: | |||
<pre> | |||
compress | |||
/home/pacs/xyz00/var/monit.log { | |||
rotate 2 | |||
weekly | |||
} | |||
</pre> | |||
Nun brauchen wir noch einen Aufruf von logrotate durch [[cron]]. Bitte beachten, logrotate merkt sich den letzten Zustand der Logdatei in einem Statusfile. Das muss in der [[cron#crontab|crontab]] mit angegeben werden. Wir editieren die Crontab und schreiben: | |||
27 7 * * 5 logrotate -s /home/pacs/xyz00/.logrotate_state /home/pacs/xyz00/.logrotate | |||
Damit wird jeden Freitag um 7:27 Uhr das monit.log "rotiert". '''Achtung:''' bitte einen andern Tag und eine andere Uhrzeit wählen, damit nicht alle logrotates zur gleichen Zeit starten. |
Version vom 25. Juli 2009, 17:33 Uhr
Monit ist ein resourcensparendes Programm zur Überwachung eigener Daemons. Es fragt regelmäßig den Zustand des zu überwachenden Prozesses ab und kann bei einem Absturz den Prozess selbstständig neu starten. Hier wird die Nutzung von Monit für eigenen Apache2 beschrieben.
Konfiguration
Monit sucht seine Konfiguration beim Start beim Start zuerst in der Datei ~/.monitrc im Homeverzeichnis des Users, der monit startet.
Wir erstellen also diese Datei im Hauptverzeichnis des Users und sorgen dafür, dass sie nur von diesem gelesen und beschrieben werden kann:
xyz00@hxx:~$ cd xyz00@hxx:~$ touch .monitrc xyz00@hxx:~$ chmod 0600 .monitrc xyz00@hxx:~$ edit .monitrc
Und füllen sie mit folgendem Inhalt:
set daemon 600 set logfile /home/pacs/xyz00/var/monit.log set mailserver localhost set alert admin@example.tld check process apache2 with pidfile /home/pacs/xyz00/etc/apache2/run/apache2.pid start program "/home/pacs/xyz00/etc/apache2/apache2_start" stop program "/home/pacs/xyz00/etc/apache2/apache2_stop" if failed host example.tld port 8080 with timeout 60 seconds then restart
Achtung: Dieses Beispiel geht davon aus, dass die entsprechenden Start- und Stopskripte existieren und der Pfad zum pidfile des Apachen stimmt.
Monit Starten und Stoppen
Start: monit
Stop: monit quit
Start eigener Daemons beim Start des Servers
In die eigene crontab folgenden Eintrag:
@reboot /usr/sbin/monit -c "/home/pacs/xyz00/.monitrc"
Logfiles kontrollieren
Monit loggt entsprechend der Konfiguration seine "Taten" in ~/var/monit.log
Damit das Logfile nicht zu groß wird, benutzen wir logrotate, das von cron aufgerufen, einmal pro Woche das Logfile komprimiert und zwei alte Versionen hält. Dazu erstellen wir die Konfigdatei .logrotate im Hauptverzeichnis des Users:
touch .logrotate
Darin schreiben wir:
compress /home/pacs/xyz00/var/monit.log { rotate 2 weekly }
Nun brauchen wir noch einen Aufruf von logrotate durch cron. Bitte beachten, logrotate merkt sich den letzten Zustand der Logdatei in einem Statusfile. Das muss in der crontab mit angegeben werden. Wir editieren die Crontab und schreiben:
27 7 * * 5 logrotate -s /home/pacs/xyz00/.logrotate_state /home/pacs/xyz00/.logrotate
Damit wird jeden Freitag um 7:27 Uhr das monit.log "rotiert". Achtung: bitte einen andern Tag und eine andere Uhrzeit wählen, damit nicht alle logrotates zur gleichen Zeit starten.