[Zope-Checkins] CVS: ZODB3/zdaemon - sample.conf:1.5 schema.xml:1.6 zdctl.py:1.22 zdoptions.py:1.9 zdrun.py:1.7
Guido van Rossum
guido@python.org
Wed, 22 Jan 2003 16:22:59 -0500
Update of /cvs-repository/ZODB3/zdaemon
In directory cvs.zope.org:/tmp/cvs-serv10094/zdaemon
Modified Files:
sample.conf schema.xml zdctl.py zdoptions.py zdrun.py
Log Message:
Rename options.zdirectory to options.directory.
Add an <eventlog> section to the runner schema.
Some comment and docstring tweakage.
=== ZODB3/zdaemon/sample.conf 1.4 => 1.5 ===
--- ZODB3/zdaemon/sample.conf:1.4 Tue Jan 21 13:52:19 2003
+++ ZODB3/zdaemon/sample.conf Wed Jan 22 16:22:56 2003
@@ -13,3 +13,10 @@
directory /
default-to-interactive True
</runner>
+
+<eventlog>
+ level info
+ <logfile>
+ path /tmp/zdrun.log
+ </logfile>
+</eventlog>
=== ZODB3/zdaemon/schema.xml 1.5 => 1.6 ===
--- ZODB3/zdaemon/schema.xml:1.5 Tue Jan 21 13:52:19 2003
+++ ZODB3/zdaemon/schema.xml Wed Jan 22 16:22:56 2003
@@ -4,6 +4,8 @@
Schema for zdctl.py and zdrun.py.
</description>
+ <import package="zLOG"/>
+
<sectiontype name="runner">
<key name="python" datatype="existing-path" />
<key name="zdrun" datatype="existing-path" />
@@ -20,5 +22,7 @@
</sectiontype>
<section name="*" type="runner" attribute="runner" required="yes" />
+
+ <section name="*" type="eventlog" attribute="eventlog" required="no" />
</schema>
=== ZODB3/zdaemon/zdctl.py 1.21 => 1.22 ===
--- ZODB3/zdaemon/zdctl.py:1.21 Tue Jan 21 13:52:19 2003
+++ ZODB3/zdaemon/zdctl.py Wed Jan 22 16:22:56 2003
@@ -196,7 +196,7 @@
"-d",
"-s", self.options.sockname,
"-x", ",".join(map(str, self.options.exitcodes)),
- "-z", self.options.zdirectory,
+ "-z", self.options.directory,
]
if self.options.forever:
args.append("-f")
@@ -316,7 +316,7 @@
print "sockname: ", repr(self.options.sockname)
print "exitcodes: ", repr(self.options.exitcodes)
print "user: ", repr(self.options.user)
- print "zdirectory: ", repr(self.options.zdirectory)
+ print "directory: ", repr(self.options.directory)
def show_python(self):
version = sys.version.replace("\n", "\n ")
=== ZODB3/zdaemon/zdoptions.py 1.8 => 1.9 ===
--- ZODB3/zdaemon/zdoptions.py:1.8 Tue Jan 21 13:19:38 2003
+++ ZODB3/zdaemon/zdoptions.py Wed Jan 22 16:22:56 2003
@@ -251,7 +251,7 @@
if self.logsectionname:
self.load_logconf(self.logsectionname)
- def load_logconf(self, sectname="logger"):
+ def load_logconf(self, sectname="eventlog"):
parts = sectname.split(".")
obj = self.configroot
for p in parts:
@@ -287,7 +287,7 @@
self.add("exitcodes", "runner.exit_codes", "x:", "exit-codes=",
list_of_ints, default=[0, 2])
self.add("user", "runner.user", "u:", "user=")
- self.add("zdirectory", "runner.directory", "z:", "directory=",
+ self.add("directory", "runner.directory", "z:", "directory=",
ZConfig.datatypes.existing_directory, default="/")
=== ZODB3/zdaemon/zdrun.py 1.6 => 1.7 ===
--- ZODB3/zdaemon/zdrun.py:1.6 Tue Jan 21 13:51:12 2003
+++ ZODB3/zdaemon/zdrun.py Wed Jan 22 16:22:56 2003
@@ -19,7 +19,7 @@
Options:
-C/--configuration URL -- configuration file or URL
-b/--backoff-limit SECONDS -- set backoff limit to SECONDS (default 10)
--d/--daemon-- run as a proper daemon; fork a subprocess, close files etc.
+-d/--daemon -- run as a proper daemon; fork a subprocess, setsid(), etc.
-f/--forever -- run forever (by default, exit when backoff limit is exceeded)
-h/--help -- print this usage message and exit
-s/--socket-name SOCKET -- Unix socket name for client (default "zdsock")
@@ -89,6 +89,7 @@
class ZDRunOptions(RunnerOptions):
positional_args_allowed = 1
+ logsectionname = "eventlog"
program = None
def realize(self, *args, **kwds):
@@ -321,14 +322,14 @@
os._exit(0)
# Child
info("daemonizing the process")
- if self.options.zdirectory:
+ if self.options.directory:
try:
- os.chdir(self.options.zdirectory)
+ os.chdir(self.options.directory)
except os.error, err:
warn("can't chdir into %r: %s" %
- (self.options.zdirectory, err))
+ (self.options.directory, err))
else:
- info("set current directory: %r" % self.options.zdirectory)
+ info("set current directory: %r" % self.options.directory)
os.close(0)
sys.stdin = sys.__stdin__ = open("/dev/null")
os.close(1)
@@ -336,6 +337,11 @@
os.close(2)
sys.stderr = sys.__stderr__ = open("/dev/null", "w")
os.setsid()
+ # XXX Stevens, in his Advanced Unix book, section 13.3 (page
+ # 417) also recommends calling umask(0) and closing unused
+ # file descriptors. In his Network Programming book, he
+ # additionally recommends ignoring SIGHUP and forking again
+ # after the setsid() call, for obscure SVR4 reasons.
mood = 1 # 1: up, 0: down, -1: suicidal
delay = 0 # If nonzero, delay starting or killing until this time