From 6ccf74f9c12e0e3f7031b11c22c822fe5ca1469b Mon Sep 17 00:00:00 2001 From: anhefti Date: Wed, 31 May 2023 09:12:46 +0200 Subject: [PATCH] SEBSERV-445 better ping batch strategy? --- .../session/impl/ExamSessionServiceImpl.java | 6 ++--- .../session/impl/SEBClientPingService.java | 23 +++++++++++++------ 2 files changed, 19 insertions(+), 10 deletions(-) diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/ExamSessionServiceImpl.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/ExamSessionServiceImpl.java index 7ca45549..d8d89ff9 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/ExamSessionServiceImpl.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/ExamSessionServiceImpl.java @@ -378,9 +378,9 @@ public class ExamSessionServiceImpl implements ExamSessionService { @Override public ClientConnectionDataInternal getConnectionDataInternal(final String connectionToken) { - //synchronized (ExamSessionCacheService.CLIENT_CONNECTION_CREATION_LOCK) { - return this.examSessionCacheService.getClientConnection(connectionToken); - //} + synchronized (ExamSessionCacheService.CLIENT_CONNECTION_CREATION_LOCK) { + return this.examSessionCacheService.getClientConnection(connectionToken); + } } @Override diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/SEBClientPingService.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/SEBClientPingService.java index e5b7602d..db0b4959 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/SEBClientPingService.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/SEBClientPingService.java @@ -8,8 +8,9 @@ package ch.ethz.seb.sebserver.webservice.servicelayer.session.impl; -import java.util.HashMap; +import java.util.HashSet; import java.util.Map; +import java.util.Set; import org.apache.commons.lang3.StringUtils; import org.ehcache.impl.internal.concurrent.ConcurrentHashMap; @@ -45,7 +46,7 @@ public class SEBClientPingService { } @Scheduled( - fixedDelayString = "${sebserver.webservice.api.exam.session.ping.batch.interval:500}", + fixedDelayString = "${sebserver.webservice.api.exam.session.ping.batch.interval:100}", initialDelay = 1000) public void processPings() { if (this.pings.isEmpty()) { @@ -60,12 +61,16 @@ public class SEBClientPingService { } try { - final Map pp = new HashMap<>(this.pings); - this.pings.clear(); + final Set connections = new HashSet<>(this.pings.keySet()); - pp.entrySet() - .stream() - .forEach(entry -> processPing(entry.getKey(), entry.getValue(), startTime)); + connections.stream().forEach(cid -> processPing( + cid, + this.pings.remove(cid), + Utils.getMillisecondsNow())); + +// pp.entrySet() +// .stream() +// .forEach(entry -> processPing(entry.getKey(), entry.getValue(), startTime)); if (log.isTraceEnabled()) { log.trace("****** Processing {} SEB pings tuck: {}", Utils.getMillisecondsNow() - startTime); @@ -83,6 +88,10 @@ public class SEBClientPingService { final String connectionToken, final String instructionConfirm) { + if (connectionToken == null) { + return null; + } + if (instructionConfirm != null) { this.pings.put(connectionToken, instructionConfirm); } else if (!this.pings.containsKey(connectionToken)) {