[Zodb-checkins] SVN: ZODB/branches/3.8/src/ZEO/ClientStorage.py The
order of operations seemed odd. If we get a new connection, we
Jim Fulton
jim at zope.com
Tue Jul 8 17:50:53 EDT 2008
Log message for revision 88126:
The order of operations seemed odd. If we get a new connection, we
should close the old connection, and mark ourselves dissconnected --
or so it seems. :) I'm chasing connection-invalidation bugs and this
rearrangement makes the logic seem a bit simpler to me and sets the
stage for a later fix for the invalidation problems.
Changed:
U ZODB/branches/3.8/src/ZEO/ClientStorage.py
-=-
Modified: ZODB/branches/3.8/src/ZEO/ClientStorage.py
===================================================================
--- ZODB/branches/3.8/src/ZEO/ClientStorage.py 2008-07-08 21:37:59 UTC (rev 88125)
+++ ZODB/branches/3.8/src/ZEO/ClientStorage.py 2008-07-08 21:50:53 UTC (rev 88126)
@@ -488,23 +488,25 @@
# this method before it was stopped.
return
- # invalidate our db cache
- if self._db is not None:
- self._db.invalidateCache()
if self._connection is not None:
+ # If we are upgrading from a read-only fallback connection,
+ # we must close the old connection to prevent it from being
+ # used while the cache is verified against the new connection.
+ self._connection.close()
+ self._connection = None
+ self._ready.clear()
reconnect = 1
else:
reconnect = 0
+
self.set_server_addr(conn.get_addr())
-
- # If we are upgrading from a read-only fallback connection,
- # we must close the old connection to prevent it from being
- # used while the cache is verified against the new connection.
- if self._connection is not None:
- self._connection.close()
self._connection = conn
+ # invalidate our db cache
+ if self._db is not None:
+ self._db.invalidateCache()
+
if reconnect:
log2("Reconnected to storage: %s" % self._server_addr)
else:
More information about the Zodb-checkins
mailing list