[Zope-Checkins] CVS: ZODB3/zdaemon - zdaemon.py:1.2
Guido van Rossum
guido@python.org
Fri, 8 Nov 2002 14:16:31 -0500
Update of /cvs-repository/ZODB3/zdaemon
In directory cvs.zope.org:/tmp/cvs-serv4855
Modified Files:
zdaemon.py
Log Message:
Docstring and usage() tweakage. Add TODO list.
=== ZODB3/zdaemon/zdaemon.py 1.1 => 1.2 ===
--- ZODB3/zdaemon/zdaemon.py:1.1 Thu Nov 7 17:44:00 2002
+++ ZODB3/zdaemon/zdaemon.py Fri Nov 8 14:16:30 2002
@@ -1,18 +1,42 @@
#! /usr/bin/env python
"""
-zdaemon -- run a program as a daemon.
+zdaemon -- run an application as a daemon.
-Usage: python zdaemon.py [zdaemon-options] program [program-options]
+Usage: python zdaemon.py [zdaemon-options] program [program-arguments]
Options:
-
--d -- run as a proper daemon; fork a background process, close files etc.
--h -- print usage message and exit
+ -d -- run as a proper daemon; fork a background process, close files etc.
+ -h -- print usage message and exit
Arguments:
+ program [program-arguments] -- an arbitrary application to run
+
+This daemon manager has two purposes: it restarts the application when
+it dies, and (when requested to do so with the -d option) it runs the
+application in the background, detached from the foreground tty
+session that started it (if any).
+
+Important: if at any point the application exits with exit status 2,
+it is not restarted. Any other form of termination (either being
+killed by a signal or exiting with an exit status other than 2) causes
+it to be restarted.
+"""
+
+"""
+XXX TO DO
+
+- A parametrizable "governor" on the automatic restart, limiting the
+ frequency of restarts and possible stopping altogether if the
+ application fails too often
+
+- A way to stop both the daemon manager and the application.
+
+- A way to restart the application.
+
+- More control over logging (zdaemon logging should be controllable
+ separate from application logging).
-program [program-options] -- an arbitrary command line to be run
"""
import os
@@ -50,7 +74,8 @@
self.info("opts=%s" % repr(opts))
for o, a in opts:
if o == "-h":
- self.usage(exit=0)
+ print __doc__,
+ self.exit()
if o == "-d":
self.daemon += 1
@@ -68,7 +93,7 @@
try:
st = os.stat(filename)
except os.error:
- self.usage("can't stat command: %s\n" % repr(command))
+ self.usage("can't stat program %s" % repr(command))
else:
path = self.getpath()
for dir in path:
@@ -81,10 +106,10 @@
if mode & 0111:
break
else:
- self.usage("can't find command: %s on PATH %s\n" %
+ self.usage("can't find program %s on PATH %s" %
(repr(command), path))
if not os.access(filename, os.X_OK):
- self.usage("no permission to run command %s\n" % repr(filename))
+ self.usage("no permission to run program %s" % repr(filename))
return filename
def getpath(self):
@@ -207,13 +232,11 @@
# Error handling
- def usage(self, msg=None, exit=2):
- if msg:
- self.errwrite("Error: %s\n" % str(msg))
- if exit == 2:
- self.error(str(msg))
- self.errwrite(__doc__)
- self.exit(exit)
+ def usage(self, msg):
+ self.errwrite("Error: %s\n" % str(msg))
+ self.error(str(msg))
+ self.errwrite("For help, use zdaemon.py -h\n")
+ self.exit(2)
def errwrite(self, msg):
sys.stderr.write(msg)