summaryrefslogtreecommitdiffstats
path: root/src/test/osd
diff options
context:
space:
mode:
authorSridhar Seshasayee <sseshasa@redhat.com>2022-10-27 07:02:46 +0200
committerSridhar Seshasayee <sseshasa@redhat.com>2023-01-09 15:24:44 +0100
commitb12780667f7b038f615d198c225f761ad7191ea9 (patch)
treeb55d932074e5c711607a27ecd138866ad0bd0e81 /src/test/osd
parentMerge pull request #49637 from zdover23/wip-doc-2023-01-05-top-bar-scroll-mar... (diff)
downloadceph-b12780667f7b038f615d198c225f761ad7191ea9.tar.xz
ceph-b12780667f7b038f615d198c225f761ad7191ea9.zip
osd: Restore defaults of mClock built-in profiles upon modification
The QoS parameters (res, wgt, lim) of mClock profiles are not allowed to be modified by users using commands like "config set" or via admin socket. handle_conf_change() does not allow changes to any built-in mClock profile at the mClock scheduler. But the config subsystem showed the change as expected for the built-in mClock profile QoS parameters. This misled the user into thinking that the change was made at the mClock server when it was not the case. The above issue is the result of the config "levels" used by the config subsystem. The inital built-in QoS params are set at the CONF_DEFAULT level. This allows the user to modify the built-in QoS params using "config set" command which sets values at CONF_MON level which has higher priority than CONF_DEFAULT level. The new value is persisted on the mon store and therefore the config subsystem shows the change when "config show" command is issued. To prevent the above, this commit adds changes to restore the defaults set for the built-in profiles by removing the new config changes from the MON store. This results in the original defaults to come back into effect and maintain a consistent view of the built-in profile across all levels. To accomplish this, the mClock scheduler is provided with additional information like the OSD id, shard id and a pointer to the MonClient using which the Mon store command to remove the option is executed. A standalone test is added to verify that built-in params cannot be modified and the original profile params are retained. Fixes: https://tracker.ceph.com/issues/57533 Signed-off-by: Sridhar Seshasayee <sseshasa@redhat.com>
Diffstat (limited to 'src/test/osd')
-rw-r--r--src/test/osd/TestMClockScheduler.cc8
1 files changed, 7 insertions, 1 deletions
diff --git a/src/test/osd/TestMClockScheduler.cc b/src/test/osd/TestMClockScheduler.cc
index 0feb427ec10..7e1971b1359 100644
--- a/src/test/osd/TestMClockScheduler.cc
+++ b/src/test/osd/TestMClockScheduler.cc
@@ -27,8 +27,11 @@ int main(int argc, char **argv) {
class mClockSchedulerTest : public testing::Test {
public:
+ int whoami;
uint32_t num_shards;
+ int shard_id;
bool is_rotational;
+ MonClient *monc;
mClockScheduler q;
uint64_t client1;
@@ -36,9 +39,12 @@ public:
uint64_t client3;
mClockSchedulerTest() :
+ whoami(0),
num_shards(1),
+ shard_id(0),
is_rotational(false),
- q(g_ceph_context, num_shards, is_rotational),
+ monc(nullptr),
+ q(g_ceph_context, whoami, num_shards, shard_id, is_rotational, monc),
client1(1001),
client2(9999),
client3(100000001)