Commit 743f14c4 authored by Vincent Pelletier's avatar Vincent Pelletier

Handle answers after sending abort notifications (improving parallelism).

git-svn-id: https://svn.erp5.org/repos/neo/trunk@2042 71dcc9de-d417-0410-9af5-da40c76e7ee4
parent cd7677dc
...@@ -722,19 +722,6 @@ class Application(object): ...@@ -722,19 +722,6 @@ class Application(object):
if transaction is not self.local_var.txn: if transaction is not self.local_var.txn:
return return
# Just wait for responses to arrive. If any leads to an exception,
# log it and continue: we *must* eat all answers to not disturb the
# next transaction.
queue = self.local_var.queue
pending = self.dispatcher.pending
_waitAnyMessage = self._waitAnyMessage
while pending(queue):
try:
_waitAnyMessage()
except:
logging.error('Exception in tpc_abort: %s',
traceback.format_exc())
tid = self.local_var.tid tid = self.local_var.tid
# select nodes where transaction was stored # select nodes where transaction was stored
cell_set = set(self._getCellListForTID(tid, cell_set = set(self._getCellListForTID(tid,
...@@ -754,6 +741,20 @@ class Application(object): ...@@ -754,6 +741,20 @@ class Application(object):
# Abort the transaction in the primary master node. # Abort the transaction in the primary master node.
conn = self._getMasterConnection() conn = self._getMasterConnection()
conn.notify(p) conn.notify(p)
# Just wait for responses to arrive. If any leads to an exception,
# log it and continue: we *must* eat all answers to not disturb the
# next transaction.
queue = self.local_var.queue
pending = self.dispatcher.pending
_waitAnyMessage = self._waitAnyMessage
while pending(queue):
try:
_waitAnyMessage()
except:
logging.error('Exception in tpc_abort: %s',
traceback.format_exc())
self.local_var.clear() self.local_var.clear()
@profiler_decorator @profiler_decorator
......
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