From cb1fff3cb6a944d1f9cc67f8aa8b1d92648bbade Mon Sep 17 00:00:00 2001 From: llahav-amzn <118261070+llahav-amzn@users.noreply.github.com> Date: Thu, 5 Jan 2023 02:26:46 +0200 Subject: [PATCH] In cluster-mode enabled, override the databases config at startup to 1 (#11555) In cluster-mode, only DB0 is supported so all data must reside in that database. There is a single check that validates that data loaded from an RDB all resides in DB0. This check is performed after all the data is loaded which makes it difficult to identify where the non DB0 data resides as well as does a bunch of unnecessary work to load incompatible data. This change override the database config at startup to 1 to throw an error when attempting to add data to a database other than DB0. Co-authored-by: Eran Liberty Co-authored-by: Oran Agra Co-authored-by: Madelyn Olson --- src/config.c | 6 ++++++ src/server.c | 7 +------ 2 files changed, 7 insertions(+), 6 deletions(-) diff --git a/src/config.c b/src/config.c index b4541559c..90baed9ee 100644 --- a/src/config.c +++ b/src/config.c @@ -611,6 +611,12 @@ void loadServerConfigFromString(char *config) { goto loaderr; } + /* in case cluster mode is enabled dbnum must be 1 */ + if (server.cluster_enabled && server.dbnum > 1) { + serverLog(LL_WARNING, "WARNING: Changing databases number from %d to 1 since we are in cluster mode", server.dbnum); + server.dbnum = 1; + } + /* To ensure backward compatibility and work while hz is out of range */ if (server.config_hz < CONFIG_MIN_HZ) server.config_hz = CONFIG_MIN_HZ; if (server.config_hz > CONFIG_MAX_HZ) server.config_hz = CONFIG_MAX_HZ; diff --git a/src/server.c b/src/server.c index eaad37c07..f01e7382d 100644 --- a/src/server.c +++ b/src/server.c @@ -7202,12 +7202,7 @@ int main(int argc, char **argv) { aofOpenIfNeededOnServerStart(); aofDelHistoryFiles(); if (server.cluster_enabled) { - if (verifyClusterConfigWithData() == C_ERR) { - serverLog(LL_WARNING, - "You can't have keys in a DB different than DB 0 when in " - "Cluster mode. Exiting."); - exit(1); - } + serverAssert(verifyClusterConfigWithData() == C_OK); } for (j = 0; j < CONN_TYPE_MAX; j++) {