Commit b71e76ae authored by Kirill Smelkov's avatar Kirill Smelkov

[ZEO4] server: Always iterate over snapshot of .connections[storage_id]

Or else such iteration can race with deletion of elements in that list
on client disconnection. StorageServer.close was already iteration over
snapshot, but StorageServer.invalidate was not.

As the result sending out invalidations were subject to race wrt client
disconnections, and some invalidations could be skipped to be delivered
causing further data corruption.

Fixes Bug2 from https://github.com/zopefoundation/ZEO/issues/209
parent bf80d23d
...@@ -1105,7 +1105,7 @@ class StorageServer: ...@@ -1105,7 +1105,7 @@ class StorageServer:
else: else:
assert info is not None assert info is not None
for p in self.connections[storage_id]: for p in self.connections[storage_id][:]:
try: try:
if invalidated is not None and p is not conn: if invalidated is not None and p is not conn:
p.client.invalidateTransaction(tid, invalidated) p.client.invalidateTransaction(tid, invalidated)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment