]> git.apps.os.sepia.ceph.com Git - ceph.git/commitdiff
client: flush the caps release in filesystem sync 58896/head
authorXiubo Li <xiubli@redhat.com>
Mon, 29 Jul 2024 06:20:41 +0000 (14:20 +0800)
committerVenky Shankar <vshankar@redhat.com>
Fri, 16 Aug 2024 02:57:44 +0000 (08:27 +0530)
We have hit a race between cap releases and cap revoke request
that will cause the check_caps() to miss sending a cap revoke ack
to MDS. And the client will depend on the cap release to release
that revoking caps, which could be delayed for some unknown reasons.

In Kclient we have figured out the RCA about race and we need
a way to explictly trigger this manually could help to get rid
of the caps revoke stuck issue.

Fixes: https://tracker.ceph.com/issues/67221
Signed-off-by: Xiubo Li <xiubli@redhat.com>
src/client/Client.cc

index 5f78e73f922249a550c395c7fe62df32f985a868..43ec05b6b8dcc9a8e5ade7f1d49a543d8cab8af2 100644 (file)
@@ -12860,6 +12860,8 @@ int Client::_sync_fs()
   // flush the mdlog before waiting for unsafe requests.
   flush_mdlog_sync();
 
+  flush_cap_releases();
+
   // wait for unsafe mds requests
   wait_unsafe_requests();