Commit 5b965fd1 authored by Grégory Wisniewski's avatar Grégory Wisniewski

Simplify implementation of tpc_aborat(), first build the cell list, then send

abort transaction packets.


git-svn-id: https://svn.erp5.org/repos/neo/branches/prototype3@386 71dcc9de-d417-0410-9af5-da40c76e7ee4
parent 9df48c80
......@@ -574,46 +574,27 @@ class Application(object):
if transaction is not self.txn:
return
# Abort txn in node where objects were stored
aborted_node_set = set()
cell_set = set()
# select nodes where objects were stored
for oid in self.txn_data_dict.iterkeys():
partition_id = u64(oid) % self.num_partitions
cell_list = self.pt.getCellList(partition_id, True)
for cell in cell_list:
if cell.getNode() not in aborted_node_set:
conn = self.cp.getConnForNode(cell)
if conn is None:
continue
cell_set |= set(self.pt.getCellList(partition_id, True))
try:
msg_id = conn.getNextId()
p = Packet()
p.abortTransaction(msg_id, self.tid)
conn.addPacket(p)
finally:
conn.unlock()
aborted_node_set.add(cell.getNode())
# Abort in nodes where transaction was stored
# select nodes where transaction was stored
partition_id = u64(self.tid) % self.num_partitions
cell_list = self.pt.getCellList(partition_id, True)
for cell in cell_list:
if cell.getNode() not in aborted_node_set:
cell_set |= set(self.pt.getCellList(partition_id, True))
# cancel transaction one all those nodes
for cell in cell_set:
conn = self.cp.getConnForNode(cell)
if conn is None:
continue
try:
msg_id = conn.getNextId()
p = Packet()
p.abortTransaction(msg_id, self.tid)
conn.addPacket(p)
conn.addPacket(Packet().abortTransaction(conn.getNextId(), self.tid))
finally:
conn.unlock()
aborted_node_set.add(cell.getNode())
# Abort the transaction in the primary master node.
conn = self.master_conn
conn.lock()
......
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