Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ceph-disk: Adding retry loop in get_partition_dev()
There is very rare cases where get_partition_dev() is called before the actual partition is available in /sys/block/<device>. It appear that waiting a very short is usually enough to get the partition beein populated. Analysis: update_partition() is supposed to be enough to avoid any racing between events sent by parted/sgdisk/partprobe and the actual creation on the /sys/block/<device>/* entrypoint. On our CI that race occurs pretty often but trying to reproduce it locally never been possible. This patch is almost a workaround rather than a fix to the real problem. It offer retrying after a very short to be make a chance the device to appear. This approach have been succesful on the CI. Note his patch is not changing the timing when the device is perfectly created on time and just differ by a 1/5th up to 2 seconds when the bug occurs. A typical output from the build running on a CI with that code. command_check_call: Running command: /usr/bin/udevadm settle --timeout=600 get_dm_uuid: get_dm_uuid /dev/sda uuid path is /sys/dev/block/8:0/dm/uuid get_partition_dev: Try 1/10 : partition 2 for /dev/sda does not in /sys/block/sda get_partition_dev: Found partition 2 for /dev/sda after 1 tries get_dm_uuid: get_dm_uuid /dev/sda uuid path is /sys/dev/block/8:0/dm/uuid get_dm_uuid: get_dm_uuid /dev/sda2 uuid path is /sys/dev/block/8:2/dm/uuid fixes: #19428 Signed-off-by: Erwan Velu <erwan@redhat.com> (cherry picked from commit 93e7b95)
- Loading branch information