Browse Source

SubProtocolWebSocketHandler closes sessions outside of lifecycle monitor

Issue: SPR-16488
pull/1679/merge
Juergen Hoeller 8 years ago
parent
commit
3c631f8ea0
  1. 20
      spring-websocket/src/main/java/org/springframework/web/socket/messaging/SubProtocolWebSocketHandler.java

20
spring-websocket/src/main/java/org/springframework/web/socket/messaging/SubProtocolWebSocketHandler.java

@ -245,6 +245,7 @@ public class SubProtocolWebSocketHandler @@ -245,6 +245,7 @@ public class SubProtocolWebSocketHandler
@Override
public final void start() {
Assert.isTrue(this.defaultProtocolHandler != null || !this.protocolHandlers.isEmpty(), "No handlers");
synchronized (this.lifecycleMonitor) {
this.clientOutboundChannel.subscribe(this);
this.running = true;
@ -256,14 +257,16 @@ public class SubProtocolWebSocketHandler @@ -256,14 +257,16 @@ public class SubProtocolWebSocketHandler
synchronized (this.lifecycleMonitor) {
this.running = false;
this.clientOutboundChannel.unsubscribe(this);
for (WebSocketSessionHolder holder : this.sessions.values()) {
try {
holder.getSession().close(CloseStatus.GOING_AWAY);
}
catch (Throwable ex) {
if (logger.isWarnEnabled()) {
logger.warn("Failed to close '" + holder.getSession() + "': " + ex);
}
}
// Proactively notify all active WebSocket sessions
for (WebSocketSessionHolder holder : this.sessions.values()) {
try {
holder.getSession().close(CloseStatus.GOING_AWAY);
}
catch (Throwable ex) {
if (logger.isWarnEnabled()) {
logger.warn("Failed to close '" + holder.getSession() + "': " + ex);
}
}
}
@ -291,6 +294,7 @@ public class SubProtocolWebSocketHandler @@ -291,6 +294,7 @@ public class SubProtocolWebSocketHandler
if (!session.isOpen()) {
return;
}
this.stats.incrementSessionCount(session);
session = decorateSession(session);
this.sessions.put(session.getId(), new WebSocketSessionHolder(session));

Loading…
Cancel
Save