[Zope-Checkins] CVS: Zope/lib/python/zdaemon - Daemon.py:1.14.6.2 __init__.py:1.4.26.1 zdaemon.py:1.3.2.2 Heartbeat.py:NONE SignalHandler.py:NONE ZDaemonLogging.py:NONE
Andreas Jung
andreas@andreas-jung.com
Sat, 16 Nov 2002 11:40:47 -0500
Update of /cvs-repository/Zope/lib/python/zdaemon
In directory cvs.zope.org:/tmp/cvs-serv25283/zdaemon
Modified Files:
Tag: ajung-restructuredtext-integration-branch
Daemon.py __init__.py zdaemon.py
Removed Files:
Tag: ajung-restructuredtext-integration-branch
Heartbeat.py SignalHandler.py ZDaemonLogging.py
Log Message:
merge from trunk
=== Zope/lib/python/zdaemon/Daemon.py 1.14.6.1 => 1.14.6.2 ===
--- Zope/lib/python/zdaemon/Daemon.py:1.14.6.1 Sat Nov 9 03:43:01 2002
+++ Zope/lib/python/zdaemon/Daemon.py Sat Nov 16 11:40:46 2002
@@ -13,7 +13,6 @@
##############################################################################
import os, sys, time, signal
-from ZDaemonLogging import pstamp
import zLOG
pyth = sys.executable
@@ -146,3 +145,6 @@
if startswith('SIG') and not startswith('SIG_'):
_signals[v] = k
return _signals.get(n, 'unknown')
+
+def pstamp(message, sev):
+ zLOG.LOG("zdaemon", sev, message)
=== Zope/lib/python/zdaemon/__init__.py 1.4 => 1.4.26.1 ===
--- Zope/lib/python/zdaemon/__init__.py:1.4 Wed Aug 14 18:12:52 2002
+++ Zope/lib/python/zdaemon/__init__.py Sat Nov 16 11:40:46 2002
@@ -12,46 +12,6 @@
# FOR A PARTICULAR PURPOSE
#
##############################################################################
-"""
-
-zinit, slightly smarter server manager and ZServer startup script.
-
- zinit will:
-
- - Fork a parent and a child
-
- - restart the child if it dies
-
- - write a pid file so you can kill (the parent)
-
- - reports the childs pid to stdout so you can kill that too
-
-TODO
-
- - Have the parent reap the children when it dies
-
- - etc.
-
-"""
+"""zdaemon -- a package to manage a daemon application."""
from Daemon import run
-
-# XXX Is the following a useful feature?
-
-def main():
- import sys
- argv=sys.argv[1:]
- if argv and argv[0][:2]=='-p':
- pidf=argv[0][2:]
- del argv[0]
- else:
- pidf=''
-
- if not argv:
- print __doc__ % vars()
- print
- print 'Error: no script given'
-
- run(argv, pidf)
-
-if __name__ == '__main__': main()
=== Zope/lib/python/zdaemon/zdaemon.py 1.3.2.1 => 1.3.2.2 === (842/942 lines abridged)
--- Zope/lib/python/zdaemon/zdaemon.py:1.3.2.1 Sat Nov 9 03:43:01 2002
+++ Zope/lib/python/zdaemon/zdaemon.py Sat Nov 16 11:40:46 2002
@@ -4,23 +4,42 @@
zdaemon -- run an application as a daemon.
Usage: python zdaemon.py [zdaemon-options] program [program-arguments]
+Or: python zdaemon.py -c [command]
Options:
-b SECONDS -- set backoff limit to SECONDS (default 10; see below)
+ -c -- client mode, to sends a command to the daemon manager; see below
-d -- run as a proper daemon; fork a background process, close files etc.
-f -- run forever (by default, exit when the backoff limit is exceeded)
-h -- print usage message and exit
+ -s SOCKET -- Unix socket name for client communication (default "zdsock")
+ -x LIST -- list of fatal exit codes (default "0,2"; use "" to disable)
+ -z DIRECTORY -- directory to chdir into when using -d; default "/"
program [program-arguments] -- an arbitrary application to run
+Client mode options:
+ -s SOCKET -- socket name (a Unix pathname) for client communication
+ [command] -- the command to send to the daemon manager (default "status")
+
+Client commands are:
+ help -- return command help
+ status -- report application status (this is the default command)
+ kill [signal] -- send a signal to the application
+ (default signal is SIGTERM)
+ start -- start the application if not already running
+ stop -- stop the application if running; daemon manager keeps running
+ restart -- stop followed by start
+ exit -- stop the application and exit
+
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.
+Important: if at any point the application exits with an exit status
+listed by the -x option, it is not restarted. Any other form of
+termination (either being killed by a signal or exiting with an exit
+status not listed in the -x option) causes it to be restarted.
Backoff limit: when the application exits (nearly) immediately after a
restart, the daemon manager starts slowing down by delaying between
@@ -33,92 +52,154 @@
[-=- -=- -=- 842 lines omitted -=- -=- -=-]
+ if hasattr(os, "WCOREDUMP"):
+ iscore = os.WCOREDUMP(sts)
+ else:
+ iscore = sts & 0x80
+ if iscore:
+ msg += " (core dumped)"
+ return -1, msg
+ else:
+ msg = "unknown termination cause 0x%04x" % sts
+ return -1, msg
+
+_signames = None
+
+def signame(sig):
+ """Return a symbolic name for a signal.
+
+ Return "signal NNN" if there is no corresponding SIG name in the
+ signal module.
+ """
+
+ if _signames is None:
+ _init_signames()
+ return _signames.get(sig) or "signal %d" % sig
+
+def _init_signames():
+ global _signames
+ d = {}
+ for k, v in signal.__dict__.items():
+ k_startswith = getattr(k, "startswith", None)
+ if k_startswith is None:
+ continue
+ if k_startswith("SIG") and not k_startswith("SIG_"):
+ d[v] = k
+ _signames = d
+
+def get_path():
+ """Return a list corresponding to $PATH, or a default."""
+ path = ["/bin", "/usr/bin", "/usr/local/bin"]
+ if os.environ.has_key("PATH"):
+ p = os.environ["PATH"]
+ if p:
+ path = p.split(os.pathsep)
+ return path
- def log(self, msg, severity=zLOG.INFO):
- zLOG.LOG(self.getsubsystem(), severity, msg)
+# Main program
def main(args=None):
d = Daemonizer()
=== Removed File Zope/lib/python/zdaemon/Heartbeat.py ===
=== Removed File Zope/lib/python/zdaemon/SignalHandler.py ===
=== Removed File Zope/lib/python/zdaemon/ZDaemonLogging.py ===