From 8e6f4fedc27aef0f35104e1d9de614f72f7539aa Mon Sep 17 00:00:00 2001 From: Puja Jagani Date: Thu, 2 Sep 2021 11:19:55 +0530 Subject: [PATCH] [grid] Remove sessions from Redis backed session map on restart --- .../redis/RedisBackedSessionMap.java | 23 +++++++++++++++++++ .../selenium/redis/GridRedisClient.java | 4 ++++ 2 files changed, 27 insertions(+) diff --git a/java/src/org/openqa/selenium/grid/sessionmap/redis/RedisBackedSessionMap.java b/java/src/org/openqa/selenium/grid/sessionmap/redis/RedisBackedSessionMap.java index 83df505c52740..e5a65c782789d 100644 --- a/java/src/org/openqa/selenium/grid/sessionmap/redis/RedisBackedSessionMap.java +++ b/java/src/org/openqa/selenium/grid/sessionmap/redis/RedisBackedSessionMap.java @@ -25,6 +25,7 @@ import org.openqa.selenium.events.EventBus; import org.openqa.selenium.grid.config.Config; import org.openqa.selenium.grid.data.NodeRemovedEvent; +import org.openqa.selenium.grid.data.NodeRestartedEvent; import org.openqa.selenium.grid.data.Session; import org.openqa.selenium.grid.data.SessionClosedEvent; import org.openqa.selenium.grid.log.LoggingOptions; @@ -85,6 +86,8 @@ public RedisBackedSessionMap(Tracer tracer, URI serverUri, EventBus bus) { .filter(slot -> slot.getSession() != null) .map(slot -> slot.getSession().getId()) .forEach(this::remove))); + + bus.addListener(NodeRestartedEvent.listener(nodeStatus -> this.removeByUri(nodeStatus.getExternalUri()))); } public static SessionMap create(Config config) { @@ -275,6 +278,26 @@ public void remove(SessionId id) { } } + public void removeByUri(URI uri) { + List uriKeys = connection.getKeysByPattern("session:*:uri"); + + if (uriKeys.isEmpty()) { + return; + } + + String[] keys = new String[uriKeys.size()]; + keys = uriKeys.toArray(keys); + + List> keyValues = connection.mget(keys); + keyValues.stream() + .filter(entry -> entry.getValue().equals(uri.toString())) + .map(KeyValue::getKey) + .map(key -> { + String[] sessionKey = key.split(":"); + return new SessionId(sessionKey[1]); + }).forEach(this::remove); + } + @Override public boolean isReady() { return connection.isOpen(); diff --git a/java/src/org/openqa/selenium/redis/GridRedisClient.java b/java/src/org/openqa/selenium/redis/GridRedisClient.java index b2252e3dc46e7..3b62fe59b7e08 100644 --- a/java/src/org/openqa/selenium/redis/GridRedisClient.java +++ b/java/src/org/openqa/selenium/redis/GridRedisClient.java @@ -76,6 +76,10 @@ public String get(String key) { return connection.sync().get(key); } + public List getKeysByPattern(String pattern) { + return connection.sync().keys(pattern); + } + public boolean isOpen() { return connection.isOpen(); }