[Zope-Checkins] CVS: Zope/lib/python/ZEO - ClientStorage.py:1.76.2.3 StorageServer.py:1.76.2.3 runsvr.py:1.14.2.2 start.py:1.47.2.4
Chris McDonough
chrism@zope.com
Fri, 3 Jan 2003 01:37:04 -0500
Update of /cvs-repository/Zope/lib/python/ZEO
In directory cvs.zope.org:/tmp/cvs-serv28385
Modified Files:
Tag: chrism-install-branch
ClientStorage.py StorageServer.py runsvr.py start.py
Log Message:
Merging chrism-install-branch with HEAD (hopefully for one of the last
times).
=== Zope/lib/python/ZEO/ClientStorage.py 1.76.2.2 => 1.76.2.3 ===
--- Zope/lib/python/ZEO/ClientStorage.py:1.76.2.2 Sun Nov 24 18:55:25 2002
+++ Zope/lib/python/ZEO/ClientStorage.py Fri Jan 3 01:36:31 2003
@@ -266,9 +266,7 @@
def close(self):
"""Storage API: finalize the storage, releasing external resources."""
- if self._tbuf is not None:
- self._tbuf.close()
- self._tbuf = None
+ self._tbuf.close()
if self._cache is not None:
self._cache.close()
self._cache = None
@@ -611,7 +609,7 @@
self._server.vote(self._serial)
return self._check_serials()
- def tpc_begin(self, transaction, tid=None, status=' '):
+ def tpc_begin(self, txn, tid=None, status=' '):
"""Storage API: begin a transaction."""
if self._is_read_only:
raise POSException.ReadOnlyError()
@@ -620,11 +618,11 @@
# It is allowable for a client to call two tpc_begins in a
# row with the same transaction, and the second of these
# must be ignored.
- if self._transaction == transaction:
+ if self._transaction == txn:
self._tpc_cond.release()
return
self._tpc_cond.wait(30)
- self._transaction = transaction
+ self._transaction = txn
self._tpc_cond.release()
if tid is None:
@@ -635,11 +633,8 @@
id = tid
try:
- r = self._server.tpc_begin(id,
- transaction.user,
- transaction.description,
- transaction._extension,
- tid, status)
+ self._server.tpc_begin(id, txn.user, txn.description,
+ txn._extension, tid, status)
except:
# Client may have disconnected during the tpc_begin().
if self._server is not disconnected_stub:
=== Zope/lib/python/ZEO/StorageServer.py 1.76.2.2 => 1.76.2.3 ===
--- Zope/lib/python/ZEO/StorageServer.py:1.76.2.2 Sun Nov 24 18:55:25 2002
+++ Zope/lib/python/ZEO/StorageServer.py Fri Jan 3 01:36:31 2003
@@ -347,13 +347,33 @@
def zeoVerify(self, oid, s, sv):
try:
- p, os, v, pv, osv = self.zeoLoad(oid)
- except: # except what?
- return None
- if os != s:
+ os = self.storage.getSerial(oid)
+ except KeyError:
self.client.invalidateVerify((oid, ''))
- elif osv != sv:
- self.client.invalidateVerify((oid, v))
+ # XXX It's not clear what we should do now. The KeyError
+ # could be caused by an object uncreation, in which case
+ # invalidation is right. It could be an application bug
+ # that left a dangling reference, in which case it's bad.
+ else:
+ # If the client has version data, the logic is a bit more
+ # complicated. If the current serial number matches the
+ # client serial number, then the non-version data must
+ # also be valid. If the current serialno is for a
+ # version, then the non-version data can't change.
+
+ # If the version serialno isn't valid, then the
+ # non-version serialno may or may not be valid. Rather
+ # than trying to figure it whether it is valid, we just
+ # invalidate it. Sending an invalidation for the
+ # non-version data implies invalidating the version data
+ # too, since an update to non-version data can only occur
+ # after the version is aborted or committed.
+ if sv:
+ if sv != os:
+ self.client.invalidateVerify((oid, ''))
+ else:
+ if s != os:
+ self.client.invalidateVerify((oid, ''))
def endZeoVerify(self):
self.client.endVerify()
=== Zope/lib/python/ZEO/runsvr.py 1.14.2.1 => 1.14.2.2 ===
--- Zope/lib/python/ZEO/runsvr.py:1.14.2.1 Sun Nov 24 18:55:25 2002
+++ Zope/lib/python/ZEO/runsvr.py Fri Jan 3 01:36:31 2003
@@ -39,11 +39,7 @@
import socket
import zLOG
-
-import ZConfig
-import ZConfig.Common
-
-import ZODB.StorageConfig
+import ZConfig.Context
class Options:
@@ -125,7 +121,11 @@
def load_configuration(self):
if self.rootconf or not self.configuration:
return
- self.rootconf = ZConfig.load(self.configuration)
+ c = ZConfig.Context.Context()
+ try:
+ self.rootconf = c.loadURL(self.configuration)
+ except ZConfig.ConfigurationError, errobj:
+ self.usage(str(errobj))
def help(self):
"""Print a long help message (self.doc) to stdout and exit(0).
@@ -207,7 +207,7 @@
return
try:
self.hostconf = self.rootconf.getSection("Host")
- except ZConfig.Common.ConfigurationConflictingSectionError:
+ except ZConfig.ConfigurationConflictingSectionError:
if not self.hostname:
self.hostname = socket.getfqdn()
self.hostconf = self.rootconf.getSection("Host", self.hostname)
@@ -273,6 +273,7 @@
return
storagesections = self.zeoconf.getChildSections("Storage")
self.storages = {}
+ import ZODB.StorageConfig
for section in storagesections:
name = section.name
if not name:
@@ -358,8 +359,8 @@
self.server = StorageServer(self.options.address, self.storages)
def loop_forever(self):
- import asyncore
- asyncore.loop()
+ import ThreadedAsync.LoopCallback
+ ThreadedAsync.LoopCallback.loop()
def handle_sigterm(self):
info("terminated by SIGTERM")
@@ -376,6 +377,7 @@
# XXX Shouldn't this be below with _log()?
import zLOG
zLOG.initialize()
+ info("reinitialized zLOG")
def close_storages(self):
for name, storage in self.storages.items():
=== Zope/lib/python/ZEO/start.py 1.47.2.3 => 1.47.2.4 ===
--- Zope/lib/python/ZEO/start.py:1.47.2.3 Sun Nov 24 18:55:26 2002
+++ Zope/lib/python/ZEO/start.py Fri Jan 3 01:36:31 2003
@@ -19,6 +19,7 @@
import types
import errno
import socket
+import ThreadedAsync.LoopCallback
def directory(p, n=1):
d = p
@@ -95,8 +96,6 @@
def main(argv):
me = argv[0]
sys.path.insert(0, directory(me, 2))
- import zLOG
- zLOG.initialize()
global LOG, INFO, ERROR
from zLOG import LOG, INFO, WARNING, ERROR, PANIC
@@ -135,7 +134,7 @@
-p port -- port to listen on
- -h adddress -- host address to listen on
+ -h address -- host address to listen on
-s -- Don't use zdeamon
@@ -213,7 +212,7 @@
os.environ['Z_DEBUG_MODE'] = '1'
if detailed:
os.environ['STUPID_LOG_SEVERITY'] = '-300'
- zLOG.initialize()
+ rotate_logs() # reinitialize zLOG
set_uid(UID)
@@ -293,7 +292,7 @@
try:
try:
- asyncore.loop()
+ ThreadedAsync.LoopCallback.loop()
finally:
if os.path.isfile(env.zeo_pid):
os.unlink(env.zeo_pid)
@@ -314,15 +313,18 @@
init = getattr(zLOG, 'initialize', None)
if init is not None:
init()
- return
- # This will work if the minimal logger is in use, but not if some
- # other logger is active. MinimalLogger exists only in Zopes
- # pre-2.7.
- try:
- import zLOG.MinimalLogger
- zLOG.MinimalLogger._log.initialize()
- except ImportError:
- pass
+ else:
+ # This will work if the minimal logger is in use, but not if some
+ # other logger is active. MinimalLogger exists only in Zopes
+ # pre-2.7.
+ try:
+ import zLOG.MinimalLogger
+ zLOG.MinimalLogger._log.initialize()
+ except ImportError:
+ zLOG.LOG("ZEO/start.py", zLOG.WARNING,
+ "Caught USR2, could not rotate logs")
+ return
+ zLOG.LOG("ZEO/start.py", zLOG.INFO, "Caught USR2, logs rotated")
def rotate_logs_handler(signum, frame):
rotate_logs()