From: Xiubo Li Date: Tue, 20 Oct 2020 05:26:33 +0000 (-0400) Subject: qa/cephfs: add session_timeout option support X-Git-Tag: v15.2.8~5^2~1^2~8^2 X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=refs%2Fpull%2F37841%2Fhead;p=ceph.git qa/cephfs: add session_timeout option support When the mds revoking the Fwbl caps, the clients need to flush the dirty data back to the OSDs, but the flush may make the OSDs to be overloaded and slow, which may take more than 60 seconds to finish. Then the MDS daemons will report the WRN messages. For the teuthology test cases, let's just increase the timeout value to make it work. Fixes: https://tracker.ceph.com/issues/47565 Signed-off-by: Xiubo Li (cherry picked from commit 0422673b6150df851a4ea1662637a77585cde52d) --- diff --git a/qa/cephfs/overrides/session_timeout.yaml b/qa/cephfs/overrides/session_timeout.yaml new file mode 100644 index 00000000000..a7a1633371f --- /dev/null +++ b/qa/cephfs/overrides/session_timeout.yaml @@ -0,0 +1,4 @@ +overrides: + ceph: + cephfs: + session_timeout: 300 diff --git a/qa/suites/fs/basic_workload/overrides/session_timeout.yaml b/qa/suites/fs/basic_workload/overrides/session_timeout.yaml new file mode 120000 index 00000000000..fce0318c589 --- /dev/null +++ b/qa/suites/fs/basic_workload/overrides/session_timeout.yaml @@ -0,0 +1 @@ +.qa/cephfs/overrides/session_timeout.yaml \ No newline at end of file diff --git a/qa/suites/fs/thrash/overrides/session_timeout.yaml b/qa/suites/fs/thrash/overrides/session_timeout.yaml new file mode 120000 index 00000000000..fce0318c589 --- /dev/null +++ b/qa/suites/fs/thrash/overrides/session_timeout.yaml @@ -0,0 +1 @@ +.qa/cephfs/overrides/session_timeout.yaml \ No newline at end of file diff --git a/qa/suites/fs/verify/overrides/session_timeout.yaml b/qa/suites/fs/verify/overrides/session_timeout.yaml new file mode 120000 index 00000000000..fce0318c589 --- /dev/null +++ b/qa/suites/fs/verify/overrides/session_timeout.yaml @@ -0,0 +1 @@ +.qa/cephfs/overrides/session_timeout.yaml \ No newline at end of file diff --git a/qa/tasks/ceph.py b/qa/tasks/ceph.py index e9d9a4a3df0..31194e03397 100644 --- a/qa/tasks/ceph.py +++ b/qa/tasks/ceph.py @@ -1687,6 +1687,13 @@ def task(ctx, config): cephfs: max_mds: 2 + To change the mdsmap's default session_timeout (60 seconds), use:: + + tasks: + - ceph: + cephfs: + session_timeout: 300 + Note, this will cause the task to check the /scratch_devs file on each node for available devices. If no such file is found, /dev/sdb will be used. diff --git a/qa/tasks/cephfs/filesystem.py b/qa/tasks/cephfs/filesystem.py index 91895a3ea7c..bf337f84fc9 100644 --- a/qa/tasks/cephfs/filesystem.py +++ b/qa/tasks/cephfs/filesystem.py @@ -548,6 +548,9 @@ class Filesystem(MDSCluster): def set_max_mds(self, max_mds): self.set_var("max_mds", "%d" % max_mds) + def set_session_timeout(self, timeout): + self.set_var("session_timeout", "%d" % timeout) + def set_allow_standby_replay(self, yes): self.set_var("allow_standby_replay", yes) @@ -615,6 +618,11 @@ class Filesystem(MDSCluster): if max_mds > 1: self.set_max_mds(max_mds) + # If absent will use the default value (60 seconds) + session_timeout = self.fs_config.get('session_timeout', 60) + if session_timeout != 60: + self.set_session_timeout(session_timeout) + self.getinfo(refresh = True) diff --git a/qa/tasks/vstart_runner.py b/qa/tasks/vstart_runner.py index a7f976d8ea5..50f5cc48f2f 100644 --- a/qa/tasks/vstart_runner.py +++ b/qa/tasks/vstart_runner.py @@ -1119,6 +1119,7 @@ class LocalFilesystem(Filesystem, LocalMDSCluster): self.metadata_overlay = False self.data_pool_name = None self.data_pools = None + self.fs_config = None # Hack: cheeky inspection of ceph.conf to see what MDSs exist self.mds_ids = set()