Commit 330e087f authored by Aurel's avatar Aurel

reimplement dropConnection


git-svn-id: https://svn.erp5.org/repos/neo/branches/prototype3@187 71dcc9de-d417-0410-9af5-da40c76e7ee4
parent 568eebdd
......@@ -81,27 +81,17 @@ class ConnectionPool(object):
"""Drop a connection."""
for node_uuid, conn in self.connection_dict.items():
# Drop first connection which looks not used
if not conn.prending():
self.connection_dict.pop(node_uuid)
# Recheck connection again because it can have been
# returned by pool to another thread
if conn.prending():
self.connection_dict[node_uuid] = conn
continue
else:
conn.lock()
try:
if not conn.prending() and not self.app.dispatcher.registered(conn.getUUID()):
conn.close()
break
finally:
conn.unlock()
logging.info('connection to storage node %s:%d closed', *(conn.getAddress()))
def _createNodeConnection(self, node):
"""Create a connection to a given storage node."""
self.connection_lock_acquire()
try:
# check dict again, maybe another thread
# just created the connection
if self.connection_dict.has_key(node.getUUID()):
return self.connection_dict[node.getUUID()]
if self.pool_size > self.max_pool_size:
# must drop some unused connections
self._dropConnection()
......@@ -113,24 +103,33 @@ class ConnectionPool(object):
n = StorageNode(node.getServer())
self.app.nm.add(n)
self.connection_dict[node.getUUID()] = conn
conn.lock()
return conn
finally:
self.connection_lock_release()
def getConnForNode(self, node):
"""Return connection object to a given node
"""Return a locked connection object to a given node
If no connection exists, create a new one"""
self.connection_lock_acquire()
try:
if self.connection_dict.has_key(node.getUUID()):
# Already connected to node
return self.connection_dict[node.getUUID()]
conn = self.connection_dict[node.getUUID()]
conn.lock()
return conn
else:
# Create new connection to node
return self._createNodeConnection(node)
finally:
self.connection_lock_release()
def removeConnection(self, node):
"""Explicitly remove connection when a node is broken."""
self.connection_lock_acquire()
try:
if self.connection_dict.has_key(node.getUUID()):
self.connection_dict.pop(node.getUUID())
finally:
self.connection_lock_release()
class Application(object):
......@@ -287,7 +286,6 @@ class Application(object):
if conn is None:
continue
conn.lock()
try:
msg_id = conn.getNextId()
p = Packet()
......@@ -440,7 +438,6 @@ class Application(object):
if conn is None:
continue
conn.lock()
try:
msg_id = conn.getNextId()
p = Packet()
......@@ -488,7 +485,6 @@ class Application(object):
if conn is None:
continue
conn.lock()
try:
msg_id = conn.getNextId()
p = Packet()
......@@ -529,7 +525,6 @@ class Application(object):
if conn is None:
continue
conn.lock()
try:
msg_id = conn.getNextId()
p = Packet()
......@@ -549,7 +544,6 @@ class Application(object):
if conn is None:
continue
conn.lock()
try:
msg_id = conn.getNextId()
p = Packet()
......@@ -627,7 +621,6 @@ class Application(object):
if conn is None:
continue
conn.lock()
try:
msg_id = conn.getNextId()
p = Packet()
......@@ -702,7 +695,6 @@ class Application(object):
if conn is None:
continue
conn.lock()
try:
msg_id = conn.getNextId()
p = Packet()
......@@ -736,7 +728,6 @@ class Application(object):
if conn is None:
continue
conn.lock()
try:
msg_id = conn.getNextId()
p = Packet()
......@@ -782,7 +773,6 @@ class Application(object):
if conn is None:
continue
conn.lock()
try:
msg_id = conn.getNextId()
p = Packet()
......@@ -820,7 +810,6 @@ class Application(object):
if conn is None:
continue
conn.lock()
try:
msg_id = conn.getNextId()
p = Packet()
......
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