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): ...@@ -574,46 +574,27 @@ class Application(object):
if transaction is not self.txn: if transaction is not self.txn:
return return
# Abort txn in node where objects were stored cell_set = set()
aborted_node_set = set()
# select nodes where objects were stored
for oid in self.txn_data_dict.iterkeys(): for oid in self.txn_data_dict.iterkeys():
partition_id = u64(oid) % self.num_partitions partition_id = u64(oid) % self.num_partitions
cell_list = self.pt.getCellList(partition_id, True) cell_set |= set(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
try: # select nodes where transaction was stored
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
partition_id = u64(self.tid) % self.num_partitions partition_id = u64(self.tid) % self.num_partitions
cell_list = self.pt.getCellList(partition_id, True) cell_set |= set(self.pt.getCellList(partition_id, True))
for cell in cell_list:
if cell.getNode() not in aborted_node_set: # cancel transaction one all those nodes
for cell in cell_set:
conn = self.cp.getConnForNode(cell) conn = self.cp.getConnForNode(cell)
if conn is None: if conn is None:
continue continue
try: try:
msg_id = conn.getNextId() conn.addPacket(Packet().abortTransaction(conn.getNextId(), self.tid))
p = Packet()
p.abortTransaction(msg_id, self.tid)
conn.addPacket(p)
finally: finally:
conn.unlock() conn.unlock()
aborted_node_set.add(cell.getNode())
# Abort the transaction in the primary master node. # Abort the transaction in the primary master node.
conn = self.master_conn conn = self.master_conn
conn.lock() 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