summaryrefslogtreecommitdiffstats
path: root/configserver
diff options
context:
space:
mode:
authorHarald Musum <musum@yahooinc.com>2021-12-01 13:00:45 +0100
committerHarald Musum <musum@yahooinc.com>2021-12-01 13:00:45 +0100
commit7c4d2771295a4cb2b6f68b2a72c328f863c31efc (patch)
treeba498a2deedcc75039af278bb3ec9ef7c32b37a3 /configserver
parent84251d52e3e0d03cc9508895474bfc860f2d6ecd (diff)
Make sure to consider all sessions in zookeeper when deleting
Diffstat (limited to 'configserver')
-rw-r--r--configserver/src/main/java/com/yahoo/vespa/config/server/session/SessionRepository.java13
1 files changed, 11 insertions, 2 deletions
diff --git a/configserver/src/main/java/com/yahoo/vespa/config/server/session/SessionRepository.java b/configserver/src/main/java/com/yahoo/vespa/config/server/session/SessionRepository.java
index 95be59e4d26..d6d7de70ebc 100644
--- a/configserver/src/main/java/com/yahoo/vespa/config/server/session/SessionRepository.java
+++ b/configserver/src/main/java/com/yahoo/vespa/config/server/session/SessionRepository.java
@@ -346,16 +346,25 @@ public class SessionRepository {
}
public int deleteExpiredRemoteSessions(Clock clock, Duration expiryTime) {
+ List<Long> remoteSessionsFromZooKeeper = getRemoteSessionsFromZooKeeper();
+ log.log(Level.FINE, () -> "Remote sessions for tenant " + tenantName + ": " + remoteSessionsFromZooKeeper);
+
int deleted = 0;
- for (long sessionId : getRemoteSessionsFromZooKeeper()) {
+ for (long sessionId : remoteSessionsFromZooKeeper) {
Session session = remoteSessionCache.get(sessionId);
- if (session == null) continue; // Internal sessions not in sync with zk, continue
+ if (session == null) {
+ log.log(Level.FINE, () -> "Remote session " + sessionId + " is null, creating a new one");
+ session = new RemoteSession(tenantName, sessionId, createSessionZooKeeperClient(sessionId));
+ }
if (session.getStatus() == Session.Status.ACTIVATE) continue;
if (sessionHasExpired(session.getCreateTime(), expiryTime, clock)) {
log.log(Level.FINE, () -> "Remote session " + sessionId + " for " + tenantName + " has expired, deleting it");
deleteRemoteSessionFromZooKeeper(session);
deleted++;
}
+ // Avoid deleting too many in one run
+ if (deleted > 100)
+ break;
}
return deleted;
}