Version 14.1 by Ray Kiddy on 2010/11/15 19:19

Show last authors
1 == Checking App for Life ==
2
3 === Chuck Hill ===
4
5 We usually just use a script that runs as a cron job. It hits a direct action on the app that returns a known "all is OK" response. If that does not get returned, alarms ring.
6
7 === Pascal Robert ===
8
9 We use [[Nagios>>http://nagios.org]] with the check//http plugin.  This plugin actually make a HTTP (or HTTPS, if the plugin was compiled with openssl support) to our apps and check a DirectAction to see if it's answer "1".  If not, Nagios send a trigger.//
10
11 ==== Ray Kiddy ====
12
13 We use nagios in several ways. We use check//ping to make sure the machines are alive. We use check//http to check that the front-end of our cluster is responding on port 80 and we have another service that checks WebDAV directories that we use. These last need to check that authentication is working, as well as access. We also have a DirectAction that checks the whole chain, from the web server to the apps and then to the databases. We send pages only from this last service.
14
15 We check that wotaskd is running with a script that acts as a plugin. It would be nice if we could use check//http but there is no single string which tells us what the wotaskd is doing. For example, it would be helpful if there was, somewhere, a single line in the wotaskd port 1085 output which said something like "host: am1.bigserver.com, applications expected 200, applications running 200". Then we could just use the s parameter on check//http instead of doing a bunch of extra stuff ourselves.
16
17 I prefer many small checks to help diagnose problems, but sending a page in the middle of the night is only from the one service that checks the whole chain of dependencies. We now have 176 services, but I add at least a few a week. There are always more things trying to break our deployments....