ARTEMIS-3929 Improving OpenWire clientIDSet
I have seen this contention while I was testing ARTEMIS-3928 This does change any semantics and current tests should be enough to validate this change
This commit is contained in:
parent
12b81e7a25
commit
568eb70fcd
|
@ -106,7 +106,7 @@ public class OpenWireProtocolManager extends AbstractProtocolManager<Command, O
|
||||||
|
|
||||||
private final CopyOnWriteArrayList<OpenWireConnection> connections = new CopyOnWriteArrayList<>();
|
private final CopyOnWriteArrayList<OpenWireConnection> connections = new CopyOnWriteArrayList<>();
|
||||||
|
|
||||||
private final Map<String, AMQConnectionContext> clientIdSet = new HashMap<>();
|
private final Map<String, AMQConnectionContext> clientIdSet = new ConcurrentHashMap<>();
|
||||||
|
|
||||||
private String brokerName;
|
private String brokerName;
|
||||||
|
|
||||||
|
@ -226,7 +226,6 @@ public class OpenWireProtocolManager extends AbstractProtocolManager<Command, O
|
||||||
}
|
}
|
||||||
|
|
||||||
public void removeConnection(ConnectionInfo info, Throwable error) throws InvalidClientIDException {
|
public void removeConnection(ConnectionInfo info, Throwable error) throws InvalidClientIDException {
|
||||||
synchronized (clientIdSet) {
|
|
||||||
String clientId = info.getClientId();
|
String clientId = info.getClientId();
|
||||||
if (clientId != null) {
|
if (clientId != null) {
|
||||||
AMQConnectionContext context = this.clientIdSet.remove(clientId);
|
AMQConnectionContext context = this.clientIdSet.remove(clientId);
|
||||||
|
@ -239,7 +238,6 @@ public class OpenWireProtocolManager extends AbstractProtocolManager<Command, O
|
||||||
throw new InvalidClientIDException("No clientID specified for connection disconnect request");
|
throw new InvalidClientIDException("No clientID specified for connection disconnect request");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/*** if set, the OpenWire connection will bypass the tcpReadBuferSize and use this value instead.
|
/*** if set, the OpenWire connection will bypass the tcpReadBuferSize and use this value instead.
|
||||||
* This is by default -1, and it should not be used unless in extreme situations like on a slow storage. */
|
* This is by default -1, and it should not be used unless in extreme situations like on a slow storage. */
|
||||||
|
@ -404,7 +402,6 @@ public class OpenWireProtocolManager extends AbstractProtocolManager<Command, O
|
||||||
throw new InvalidClientIDException("No clientID specified for connection request");
|
throw new InvalidClientIDException("No clientID specified for connection request");
|
||||||
}
|
}
|
||||||
|
|
||||||
synchronized (clientIdSet) {
|
|
||||||
AMQConnectionContext context;
|
AMQConnectionContext context;
|
||||||
context = clientIdSet.get(clientId);
|
context = clientIdSet.get(clientId);
|
||||||
if (context != null) {
|
if (context != null) {
|
||||||
|
@ -433,7 +430,6 @@ public class OpenWireProtocolManager extends AbstractProtocolManager<Command, O
|
||||||
// init the conn
|
// init the conn
|
||||||
context.getConnection().addSessions(context.getConnectionState().getSessionIds());
|
context.getConnection().addSessions(context.getConnectionState().getSessionIds());
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
public void fireAdvisory(AMQConnectionContext context, ActiveMQTopic topic, Command copy) throws Exception {
|
public void fireAdvisory(AMQConnectionContext context, ActiveMQTopic topic, Command copy) throws Exception {
|
||||||
this.fireAdvisory(context, topic, copy, null, null);
|
this.fireAdvisory(context, topic, copy, null, null);
|
||||||
|
|
Loading…
Reference in New Issue