Project

General

Profile

Bug #50787

rbd diff between two snapshots lists entire image content with 'whole-object' switch

Added by David Herselman over 2 years ago. Updated over 1 year ago.

Status:
Resolved
Priority:
Normal
Assignee:
Target version:
-
% Done:

0%

Source:
Tags:
Backport:
pacific,octopus
Regression:
No
Severity:
3 - minor
Reviewed:
Affected Versions:
ceph-qa-suite:
Pull request ID:
Crash signature (v1):
Crash signature (v2):

Description

Hi,

I believe that the fix introduced in response to https://tracker.ceph.com/issues/42248 has broken the 'whole-object' parameter switch for rbd diff when comparing two snapshots.

The parameter is described in the man page as:

  Specifies that the diff should be limited to the extents of a  full  ob-
  ject instead of showing intra-object deltas. When the object map feature
  is enabled on an image, limiting the diff to  the  object  extents  will
  dramatically  improve  performance since the differences can be computed
  by examining the in-memory object map instead of querying RADOS for each
  object within the image.

I'm using the KRBD client with kernel 5.11.7 and Ceph Octopus 15.2.11 as part of Proxmox PVE 6.4 which is based on Debian 10. Images have the following features and I've performed offline object map checks and rebuilds (no errors reported).

To reproduce my issue I first create a new RBD image (default features are 63), map it using KRBD, write some data, create first snapshot, write a single object (4 MiB), create a second snapshot and then list the differences:

[admin@kvm1a ~]# rbd create rbd_hdd/test --size 40G
[admin@kvm1a ~]# rbd info rbd_hdd/test
rbd image 'test':
        size 40 GiB in 10240 objects
        order 22 (4 MiB objects)
        snapshot_count: 0
        id: 73363f8443987b
        block_name_prefix: rbd_data.73363f8443987b
        format: 2
        features: layering, exclusive-lock, object-map, fast-diff, deep-flatten
        op_features:
        flags:
        create_timestamp: Wed May 12 23:01:11 2021
        access_timestamp: Wed May 12 23:01:11 2021
        modify_timestamp: Wed May 12 23:01:11 2021
[admin@kvm1a ~]# rbd map rbd_hdd/test
/dev/rbd18
[admin@kvm1a ~]# dd if=/dev/zero of=/dev/rbd18 bs=64M count=1
1+0 records in
1+0 records out
67108864 bytes (67 MB, 64 MiB) copied, 0.668701 s, 100 MB/s
[admin@kvm1a ~]# sync
[admin@kvm1a ~]# rbd snap create rbd_hdd/test@snap1
[admin@kvm1a ~]# dd if=/dev/zero of=/dev/rbd18 bs=4M count=1
1+0 records in
1+0 records out
4194304 bytes (4.2 MB, 4.0 MiB) copied, 0.265691 s, 15.8 MB/s
[admin@kvm1a ~]# sync
[admin@kvm1a ~]# rbd snap create rbd_hdd/test@snap2
[admin@kvm1a ~]# rbd diff --from-snap snap1 rbd_hdd/test@snap2 --format=json
[{"offset":0,"length":4194304,"exists":"true"}]

This is all 100% perfect, when one however then adds the '--whole-object' switch it lists all allocated regions of the snapshot instead of only the differences:

[admin@kvm1b ~]# rbd diff --from-snap snap1 rbd_hdd/test@snap2 --format=json --whole-object
[{"offset":0,"length":4194304,"exists":"true"},
{"offset":4194304,"length":4194304,"exists":"true"},
{"offset":8388608,"length":4194304,"exists":"true"},
{"offset":12582912,"length":4194304,"exists":"true"},
{"offset":16777216,"length":4194304,"exists":"true"},
{"offset":20971520,"length":4194304,"exists":"true"},
{"offset":25165824,"length":4194304,"exists":"true"},
{"offset":29360128,"length":4194304,"exists":"true"},
{"offset":33554432,"length":4194304,"exists":"true"},
{"offset":37748736,"length":4194304,"exists":"true"},
{"offset":41943040,"length":4194304,"exists":"true"},
{"offset":46137344,"length":4194304,"exists":"true"},
{"offset":50331648,"length":4194304,"exists":"true"},
{"offset":54525952,"length":4194304,"exists":"true"},
{"offset":58720256,"length":4194304,"exists":"true"},
{"offset":62914560,"length":4194304,"exists":"true"}]

[admin@kvm1a ~]# rbd du rbd_hdd/test
NAME        PROVISIONED  USED
test@snap1       40 GiB   64 MiB
test@snap2       40 GiB   64 MiB
test             40 GiB    4 MiB
<TOTAL>          40 GiB  132 MiB

Regards
David Herselman


Related issues

Related to rbd - Bug #42248: rbd export-diff with --whole-object skips parent data for fast-diff enabled images Resolved
Duplicated by rbd - Bug #52915: rbd du versus rbd diff values wildly different when snapshots are present Duplicate
Copied to rbd - Backport #53027: octopus: rbd diff between two snapshots lists entire image content with 'whole-object' switch Resolved
Copied to rbd - Backport #53028: pacific: rbd diff between two snapshots lists entire image content with 'whole-object' switch Resolved

History

#1 Updated by Loïc Dachary over 2 years ago

  • Target version deleted (v15.2.11)

#2 Updated by Ilya Dryomov over 2 years ago

  • Assignee set to Ilya Dryomov

#3 Updated by Ilya Dryomov over 2 years ago

  • Related to Bug #42248: rbd export-diff with --whole-object skips parent data for fast-diff enabled images added

#4 Updated by Ilya Dryomov over 2 years ago

  • Assignee changed from Ilya Dryomov to Sunny Kumar

Sunny is looking into this.

#5 Updated by Ilya Dryomov over 2 years ago

  • Status changed from New to In Progress

#6 Updated by Sunny Kumar over 2 years ago

  • Status changed from In Progress to Fix Under Review
  • Pull request ID set to 41657

#7 Updated by Mykola Golub about 2 years ago

  • Status changed from Fix Under Review to Pending Backport
  • Backport set to pacific,octopus

#8 Updated by Backport Bot about 2 years ago

  • Copied to Backport #53027: octopus: rbd diff between two snapshots lists entire image content with 'whole-object' switch added

#9 Updated by Backport Bot about 2 years ago

  • Copied to Backport #53028: pacific: rbd diff between two snapshots lists entire image content with 'whole-object' switch added

#10 Updated by A. Saber Shenouda almost 2 years ago

It would be really appreciated if it can be pushed to Nautilus.

#11 Updated by Loïc Dachary almost 2 years ago

  • Status changed from Pending Backport to Resolved

While running with --resolve-parent, the script "backport-create-issue" noticed that all backports of this issue are in status "Resolved" or "Rejected".

#12 Updated by Ilya Dryomov over 1 year ago

  • Duplicated by Bug #52915: rbd du versus rbd diff values wildly different when snapshots are present added

#13 Updated by Ilya Dryomov over 1 year ago

A. Saber Shenouda wrote:

It would be really appreciated if it can be pushed to Nautilus.

Nautilus is no longer supported -- it went EOL in June 2021.

Also available in: Atom PDF