Is there any way supervisord can automatically restart a failed/exited/terminated job and send me a notification email with a dump of the last x lines of log file?
Answer
There is a plugin called superlance.
You install it with pip install superlance or download it at: http://pypi.python.org/pypi/superlance
The next thing you do is you go into your supervisord.conf and add the following lines:
[eventlistener:crashmail]
command=/usr/local/bin/crashmail -a -m email1@example.com
events=PROCESS_STATE
This should be followed by a "supervisorctl update". When a process "exits" you will now get a notification sent to email1@example.com.
If you only want to listen to some selected apps you can exchange the -a for a -p program1 or if it is a group group1:program2 One example would be
[eventlistener:crashmail]
command=/usr/local/bin/crashmail -p program1 -p group1:program2 -m email1@example.com
events=PROCESS_STATE
Regarding the automatic restart:
you should make sure that autorestart is set to true (it is set to unexpected by default). This way the package will be restarted 3 times. If after that it still exits, it gives up, but you can change that with startretries.
Example program:
[program:cat]
command=/bin/cat
autorestart=true
startretries=10
No comments:
Post a Comment