summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobert Gemmell <robbie@apache.org>2014-05-22 15:10:32 +0000
committerRobert Gemmell <robbie@apache.org>2014-05-22 15:10:32 +0000
commit145043153155071d7a45851a719a91a76e82f105 (patch)
tree9addd7c10ec81622d5833cda927a65e8768c3c96
parent0778dc8875fa039dba274db7ff546e394ade0d52 (diff)
downloadqpid-python-145043153155071d7a45851a719a91a76e82f105.tar.gz
QPID-5781: remove connection from the registry upon exception while closing, ensure we dont loop retrying it
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@1596899 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--qpid/java/broker-core/src/main/java/org/apache/qpid/server/connection/ConnectionRegistry.java23
1 files changed, 11 insertions, 12 deletions
diff --git a/qpid/java/broker-core/src/main/java/org/apache/qpid/server/connection/ConnectionRegistry.java b/qpid/java/broker-core/src/main/java/org/apache/qpid/server/connection/ConnectionRegistry.java
index ecd5e58986..c599ab4608 100644
--- a/qpid/java/broker-core/src/main/java/org/apache/qpid/server/connection/ConnectionRegistry.java
+++ b/qpid/java/broker-core/src/main/java/org/apache/qpid/server/connection/ConnectionRegistry.java
@@ -65,19 +65,18 @@ public class ConnectionRegistry implements IConnectionRegistry
while (!_registry.isEmpty())
{
AMQConnectionModel connection = _registry.get(0);
- closeConnection(connection, AMQConstant.CONNECTION_FORCED, replyText);
- }
- }
- private void closeConnection(AMQConnectionModel connection, AMQConstant cause, String message)
- {
- try
- {
- connection.close(cause, message);
- }
- catch (Exception e)
- {
- _logger.warn("Exception closing connection", e);
+ try
+ {
+ connection.close(AMQConstant.CONNECTION_FORCED, replyText);
+ }
+ catch (Exception e)
+ {
+ //remove this connection to ensure that we don't loop forever if it fails to close
+ _registry.remove(connection);
+
+ _logger.warn("Exception closing connection " + connection.getConnectionId() + " from " + connection.getRemoteAddressString(), e);
+ }
}
}