[Zope-Checkins] CVS: ZODB3/zdaemon - zdaemon.py:1.21
Guido van Rossum
guido@python.org
Thu, 21 Nov 2002 17:25:36 -0500
Update of /cvs-repository/ZODB3/zdaemon
In directory cvs.zope.org:/tmp/cvs-serv25340
Modified Files:
zdaemon.py
Log Message:
Rename opts to options.
=== ZODB3/zdaemon/zdaemon.py 1.20 => 1.21 ===
--- ZODB3/zdaemon/zdaemon.py:1.20 Wed Nov 20 08:43:20 2002
+++ ZODB3/zdaemon/zdaemon.py Thu Nov 21 17:25:36 2002
@@ -125,7 +125,7 @@
if progname:
self.progname = progname
try:
- self.opts, self.args = getopt.getopt(args, "b:cdfhs:u:x:z:")
+ self.options, self.args = getopt.getopt(args, "b:cdfhs:u:x:z:")
except getopt.error, msg:
self.usage(str(msg))
self._interpret_options()
@@ -137,7 +137,7 @@
When -h is detected, print the module docstring to stdout and exit(0).
"""
- for o, a in self.opts:
+ for o, a in self.options:
# Keep these in alphabetical order please!
if o == "-b":
try:
@@ -182,17 +182,17 @@
pid = 0 # Subprocess pid; 0 when not running
lasttime = 0 # Last time the subprocess was started; 0 if never
- def __init__(self, opts, args=None):
+ def __init__(self, options, args=None):
"""Constructor.
Arguments are an Options instance and a list of program
arguments; the latter's first item must be the program name.
"""
if args is None:
- args = opts.args
+ args = options.args
if not args:
- opts.usage("missing 'program' argument")
- self.opts = opts
+ options.usage("missing 'program' argument")
+ self.options = options
self.args = args
self._set_filename(args[0])
@@ -203,7 +203,7 @@
try:
st = os.stat(filename)
except os.error:
- self.opts.usage("can't stat program %r" % program)
+ self.options.usage("can't stat program %r" % program)
else:
path = get_path()
for dir in path:
@@ -216,10 +216,10 @@
if mode & 0111:
break
else:
- self.opts.usage("can't find program %r on PATH %s" %
+ self.options.usage("can't find program %r on PATH %s" %
(program, path))
if not os.access(filename, os.X_OK):
- self.opts.usage("no permission to run program %r" % filename)
+ self.options.usage("no permission to run program %r" % filename)
self.filename = filename
def spawn(self):
@@ -283,15 +283,15 @@
"""A class representing the control client."""
- def __init__(self, opts, args=None):
+ def __init__(self, options, args=None):
"""Constructor.
Arguments are an Options instance and a list of program
arguments representing the command to send to the server.
"""
- self.opts = opts
+ self.options = options
if args is None:
- args = opts.args
+ args = options.args
if not args:
self.command = "status"
else:
@@ -301,10 +301,10 @@
"""Send the command to the server and write the results to stdout."""
sock = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM)
try:
- sock.connect(self.opts.sockname)
+ sock.connect(self.options.sockname)
except socket.error, msg:
sys.stderr.write("Can't connect to %r: %s\n" %
- (self.opts.sockname, msg))
+ (self.options.sockname, msg))
sys.exit(1)
sock.send(self.command + "\n")
sock.shutdown(1) # We're not writing any more
@@ -324,50 +324,50 @@
class Daemonizer:
def main(self, args=None):
- self.opts = Options(args)
+ self.options = Options(args)
self.set_uid()
- if self.opts.isclient:
- clt = Client(self.opts)
+ if self.options.isclient:
+ clt = Client(self.options)
clt.doit()
else:
self.run()
def set_uid(self):
- if self.opts.user is None:
+ if self.options.user is None:
return
if os.name != "posix":
- self.opts.usage("-u USER only supported on Unix")
+ self.options.usage("-u USER only supported on Unix")
if os.geteuid() != 0:
- self.opts.usage("only root can use -u USER")
+ self.options.usage("only root can use -u USER")
import pwd
try:
- uid = int(self.opts.user)
+ uid = int(self.options.user)
except: # int() can raise all sorts of errors
try:
- pwrec = pwd.getpwnam(self.opts.user)
+ pwrec = pwd.getpwnam(self.options.user)
except KeyError:
- self.opts.usage("username %r not found" % self.opts.user)
+ self.options.usage("username %r not found" % self.options.user)
uid = pwrec[2]
else:
try:
pwrec = pwd.getpwuid(uid)
except KeyError:
- self.opts.usage("uid %r not found" % self.opts.user)
+ self.options.usage("uid %r not found" % self.options.user)
gid = pwrec[3]
os.setgid(gid)
os.setuid(uid)
def run(self):
- self.proc = Subprocess(self.opts)
+ self.proc = Subprocess(self.options)
self.opensocket()
try:
self.setsignals()
- if self.opts.daemon:
+ if self.options.daemon:
self.daemonize()
self.runforever()
finally:
try:
- os.unlink(self.opts.sockname)
+ os.unlink(self.options.sockname)
except os.error:
pass
@@ -377,14 +377,14 @@
def opensocket(self):
self.checkopen()
try:
- os.unlink(self.opts.sockname)
+ os.unlink(self.options.sockname)
except os.error:
pass
self.mastersocket = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM)
oldumask = None
try:
oldumask = os.umask(077)
- self.mastersocket.bind(self.opts.sockname)
+ self.mastersocket.bind(self.options.sockname)
finally:
if oldumask is not None:
os.umask(oldumask)
@@ -394,7 +394,7 @@
def checkopen(self):
s = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM)
try:
- s.connect(self.opts.sockname)
+ s.connect(self.options.sockname)
s.send("status\n")
data = s.recv(1000)
s.close()
@@ -404,7 +404,7 @@
if not data.endswith("\n"):
data += "\n"
msg = ("Another zdaemon is already up using socket %r:\n%s" %
- (self.opts.sockname, data))
+ (self.options.sockname, data))
sys.stderr.write(msg)
critical(msg)
sys.exit(1)
@@ -437,13 +437,14 @@
os._exit(0)
# Child
info("daemonizing the process")
- if self.opts.zdirectory:
+ if self.options.zdirectory:
try:
- os.chdir(self.opts.zdirectory)
+ os.chdir(self.options.zdirectory)
except os.error, err:
- warn("can't chdir into %r: %s" % (self.opts.zdirectory, err))
+ warn("can't chdir into %r: %s" %
+ (self.options.zdirectory, err))
else:
- info("set current directory: %r" % self.opts.zdirectory)
+ info("set current directory: %r" % self.options.zdirectory)
os.close(0)
sys.stdin = sys.__stdin__ = open("/dev/null")
os.close(1)
@@ -470,14 +471,14 @@
r, w, x = [self.mastersocket], [], []
if self.commandsocket:
r.append(self.commandsocket)
- timeout = self.opts.backofflimit
+ timeout = self.options.backofflimit
if self.delay:
timeout = max(0, min(timeout, self.delay - time.time()))
if timeout <= 0:
self.delay = 0
if self.killing and self.proc.pid:
self.proc.kill(signal.SIGKILL)
- self.delay = time.time() + self.opts.backofflimit
+ self.delay = time.time() + self.options.backofflimit
try:
r, w, x = select.select(r, w, x, timeout)
except select.error, err:
@@ -516,7 +517,7 @@
else:
self.governor()
self.proc.setstatus(sts)
- if es in self.opts.exitcodes:
+ if es in self.options.exitcodes:
msg = msg + "; exiting now"
info(msg)
sys.exit(es)
@@ -529,12 +530,12 @@
now = time.time()
if not self.proc.lasttime:
pass
- elif now - self.proc.lasttime < self.opts.backofflimit:
+ elif now - self.proc.lasttime < self.options.backofflimit:
# Exited rather quickly; slow down the restarts
self.backoff += 1
- if self.backoff >= self.opts.backofflimit:
- if self.opts.forever:
- self.backoff = self.opts.backofflimit
+ if self.backoff >= self.options.backofflimit:
+ if self.options.forever:
+ self.backoff = self.options.backofflimit
else:
critical("restarting too frequently; quit")
sys.exit(1)
@@ -604,7 +605,7 @@
self.proc.kill(signal.SIGTERM)
self.sendreply("Sent SIGTERM")
self.killing = 1
- self.delay = time.time() + self.opts.backofflimit
+ self.delay = time.time() + self.options.backofflimit
else:
self.sendreply("Application already stopped")
@@ -617,7 +618,7 @@
self.proc.kill(signal.SIGTERM)
self.sendreply("Sent SIGTERM; will restart later")
self.killing = 1
- self.delay = time.time() + self.opts.backofflimit
+ self.delay = time.time() + self.options.backofflimit
else:
self.proc.spawn()
self.sendreply("Application started")
@@ -631,7 +632,7 @@
self.proc.kill(signal.SIGTERM)
self.sendreply("Sent SIGTERM; will exit later")
self.killing = 1
- self.delay = time.time() + self.opts.backofflimit
+ self.delay = time.time() + self.options.backofflimit
else:
self.sendreply("Exiting now")
info("Exiting")
@@ -668,7 +669,7 @@
"lasttime=%r\n" % self.proc.lasttime +
"application=%r\n" % self.proc.pid +
"manager=%r\n" % os.getpid() +
- "backofflimit=%r\n" % self.opts.backofflimit +
+ "backofflimit=%r\n" % self.options.backofflimit +
"filename=%r\n" % self.proc.filename +
"args=%r\n" % self.proc.args)