From a2778fa27a4a07c8706d139d6ce81f5e5b062a46 Mon Sep 17 00:00:00 2001 From: Igor Zolotarev Date: Tue, 14 Nov 2023 13:34:46 +0300 Subject: [PATCH] Add issue about vshard storages marked as ALL_RW --- CHANGELOG.rst | 2 ++ cartridge/issues.lua | 6 ++++++ cartridge/roles/vshard-storage.lua | 14 +++++++++++++- rst/cartridge_admin.rst | 19 +++++++++++++++++++ test/integration/api_edit_test.lua | 7 +++++++ test/integration/api_query_test.lua | 3 +-- 6 files changed, 48 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.rst b/CHANGELOG.rst index 142fc236a..22f11b0d5 100644 --- a/CHANGELOG.rst +++ b/CHANGELOG.rst @@ -20,6 +20,8 @@ Added - new issue when ``box.info.election.leader_idle`` is too high. +- new issue about vshard storages marked as ``ALL_RW``. + ------------------------------------------------------------------------------- [2.8.4] - 2023-10-31 ------------------------------------------------------------------------------- diff --git a/cartridge/issues.lua b/cartridge/issues.lua index c7821ef16..05bce2b62 100644 --- a/cartridge/issues.lua +++ b/cartridge/issues.lua @@ -45,6 +45,12 @@ -- * warning: "Advertise URI (...) differs from clusterwide config (...)"; -- * warning: "Configuring roles is stuck on ... and hangs for ... so far"; -- +-- Vshard: +-- +-- * various vshard alerts (see vshard docs for details); +-- * warning: "Group "..." wasn't bootstrapped: ..."; +-- * warning: Vshard storages in replicaset %s marked as "all writable". +-- -- Alien members: -- -- * warning: "Instance ... with alien uuid is in the membership" - diff --git a/cartridge/roles/vshard-storage.lua b/cartridge/roles/vshard-storage.lua index 3d759450b..432a98feb 100644 --- a/cartridge/roles/vshard-storage.lua +++ b/cartridge/roles/vshard-storage.lua @@ -20,10 +20,12 @@ hotreload.whitelist_globals({ vars:new('vshard_cfg') vars:new('instance_uuid') vars:new('replicaset_uuid') +vars:new('issues', {}) local _G_vshard_backup -local function apply_config(conf, _) +local function apply_config(conf, opts) checks('table', {is_master = 'boolean'}) + vars.issues = {} local my_replicaset = conf.topology.replicasets[vars.replicaset_uuid] local group_name = my_replicaset.vshard_group or 'default' @@ -34,6 +36,15 @@ local function apply_config(conf, _) vshard_cfg.listen = box.cfg.listen vshard_cfg.replication = box.cfg.replication + if my_replicaset.all_rw and opts.is_master then + table.insert(vars.issues, { + level = 'warning', + topic = 'vshard', + message = ([[Vshard storages in replicaset %s marked as "all writable". ]] .. + [[This might not work as expected.]]):format(vars.replicaset_uuid), + }) + end + if utils.deepcmp(vshard_cfg, vars.vshard_cfg) then -- No reconfiguration required, skip it return @@ -101,4 +112,5 @@ return { on_apply_config = on_apply_config, init = init, stop = stop, + get_issues = function() return vars.issues end, } diff --git a/rst/cartridge_admin.rst b/rst/cartridge_admin.rst index d7ed7fefd..58e1eb060 100644 --- a/rst/cartridge_admin.rst +++ b/rst/cartridge_admin.rst @@ -1285,6 +1285,14 @@ Cartridge displays cluster and instances issues in WebUI: |nbsp| +* Vshard: + + * various vshard alerts (see vshard docs for details); + + * **warning**: warning: "Group "..." wasn't bootstrapped: ..."; + + * **warning**: Vshard storages in replicaset %s marked as "all writable". + * Alien members: * **warning**: "Instance ... with alien uuid is in the membership" -- @@ -1296,10 +1304,21 @@ Cartridge displays cluster and instances issues in WebUI: |nbsp| +* Expelled instances: + + * **warning**: "Replicaset ... has expelled instance ... in box.space._cluster" - + when instance was expelled from replicaset, but still remains in box.space._cluster; + * Deprecated space format: * **warning**: "Instance ... has spaces with deprecated format: space1, ..." +* Raft issues: + + * **warning**: "Raft leader idle is 10.000 on ... . + Is raft leader alive and connection is healthy?" + + * Custom issues (defined by user): * Custom roles can announce more issues with their own level, topic diff --git a/test/integration/api_edit_test.lua b/test/integration/api_edit_test.lua index 150a71a22..fe902fe03 100644 --- a/test/integration/api_edit_test.lua +++ b/test/integration/api_edit_test.lua @@ -313,4 +313,11 @@ end function g.test_all_rw_true() test_all_rw(true) + helpers.retrying({}, function() + t.assert_equals( + helpers.list_cluster_issues(g.cluster.main_server)[1].message, + ('Vshard storages in replicaset %s '):format(helpers.uuid('b')).. + 'marked as "all writable". This might not work as expected.' + ) + end) end diff --git a/test/integration/api_query_test.lua b/test/integration/api_query_test.lua index 65f4904de..5e1b52a29 100644 --- a/test/integration/api_query_test.lua +++ b/test/integration/api_query_test.lua @@ -27,7 +27,6 @@ g.before_all(function() }, { uuid = helpers.uuid('b'), roles = {'vshard-storage'}, - all_rw = true, servers = { { alias = 'storage', @@ -479,7 +478,7 @@ function g.test_replicasets() master = {uuid = helpers.uuid('b', 'b', 1)}, active_master = {uuid = helpers.uuid('b', 'b', 1)}, weight = 1, - all_rw = true, + all_rw = false, servers = { {uri = 'localhost:13302', priority = 1}, {uri = 'localhost:13304', priority = 2},