From d5b80d2b31c768bd5bdcf1084fa2335ce4aa64c4 Mon Sep 17 00:00:00 2001 From: Andreas Fankhauser <23085769+hiddenalpha@users.noreply.github.com> Date: Wed, 3 Jan 2024 18:21:15 +0100 Subject: [PATCH] [SDCISA-13736] Fix bad habits in DefaultRedisProvider. --- .../reststorage/DefaultRedisProvider.java | 21 +++++++++++++------ 1 file changed, 15 insertions(+), 6 deletions(-) diff --git a/src/main/java/org/swisspush/reststorage/DefaultRedisProvider.java b/src/main/java/org/swisspush/reststorage/DefaultRedisProvider.java index 62a3831..c384593 100644 --- a/src/main/java/org/swisspush/reststorage/DefaultRedisProvider.java +++ b/src/main/java/org/swisspush/reststorage/DefaultRedisProvider.java @@ -102,7 +102,13 @@ private Future connectToRedis() { createConnectStrings().forEach(redisOptions::addConnectionString); redis = Redis.createClient(vertx, redisOptions); - redis.connect().onSuccess(conn -> { + redis.connect().onComplete( ev -> { + if( ev.failed() ) { + promise.fail(new Exception("redis.connect()", ev.cause())); + connecting.set(false); + return; + } + var conn = ev.result(); log.info("Successfully connected to redis"); client = conn; @@ -114,23 +120,26 @@ private Future connectToRedis() { // eg, the underlying TCP connection is closed but the client side doesn't know it yet // the client tries to use the staled connection to talk to server. An exceptions will be raised if (reconnectEnabled()) { - conn.exceptionHandler(e -> attemptReconnect(0)); + conn.exceptionHandler(ex -> { + log.warn("redis connection reports problem", ex); + attemptReconnect(0); + }); } // make sure the client is reconnected on connection close // eg, the underlying TCP connection is closed with normal 4-Way-Handshake // this handler will be notified instantly if (reconnectEnabled()) { - conn.endHandler(placeHolder -> attemptReconnect(0)); + conn.endHandler(nothing -> { + log.warn("redis connection got closed"); + attemptReconnect(0); + }); } // allow further processing redisAPI = RedisAPI.api(conn); promise.complete(redisAPI); connecting.set(false); - }).onFailure(t -> { - promise.fail(t); - connecting.set(false); }); } else { promise.complete(redisAPI);