glusterfs/0497-cluster-dht-Use-percentages-for-space-check.patch
Milind Changire a902a1d5ca autobuild v3.12.2-35
Resolves: bz#1648893 bz#1654161
Signed-off-by: Milind Changire <mchangir@redhat.com>
2019-01-02 10:54:10 -05:00

146 lines
6.7 KiB
Diff

From 2029bf72400a380a4a0f1bf7f1b72816c70f9774 Mon Sep 17 00:00:00 2001
From: N Balachandran <nbalacha@redhat.com>
Date: Mon, 31 Dec 2018 17:42:27 +0530
Subject: [PATCH 497/498] cluster/dht: Use percentages for space check
With heterogenous bricks now being supported in DHT
we could run into issues where files are not migrated
even though there is sufficient space in newly added bricks
which just happen to be considerably smaller than older
bricks. Using percentages instead of absolute available
space for space checks can mitigate that to some extent.
upstream patch:https://review.gluster.org/#/c/glusterfs/+/19101/
This is not an identical backport as there were some changes
to upstream master that are not available in the downstream code.
Marking bug-1247563.t bad as that used to depend on the easier
code to prevent a file from migrating. This will be removed
once we find a way to force a file migration failure.
Change-Id: Ie89bfdd114406a986b3ff4f53b0bb0fae6574c8e
BUG: 1290124
Signed-off-by: N Balachandran <nbalacha@redhat.com>
Reviewed-on: https://code.engineering.redhat.com/gerrit/159569
Tested-by: RHGS Build Bot <nigelb@redhat.com>
Reviewed-by: Susant Palai <spalai@redhat.com>
Reviewed-by: Raghavendra Gowdappa <rgowdapp@redhat.com>
---
tests/bugs/distribute/bug-1247563.t | 3 ++
xlators/cluster/dht/src/dht-rebalance.c | 57 ++++++++++++++++++++++++---------
2 files changed, 45 insertions(+), 15 deletions(-)
diff --git a/tests/bugs/distribute/bug-1247563.t b/tests/bugs/distribute/bug-1247563.t
index f7f9258..12cd080 100644
--- a/tests/bugs/distribute/bug-1247563.t
+++ b/tests/bugs/distribute/bug-1247563.t
@@ -55,3 +55,6 @@ COUNT=`getfacl $FPATH2 |grep -c "user:root:rwx"`
EXPECT "0" echo $COUNT
cleanup;
+
+#G_TESTDEF_TEST_STATUS_CENTOS6=BAD_TEST,BUG=000000
+#G_TESTDEF_TEST_STATUS_NETBSD7=BAD_TEST,BUG=000000
diff --git a/xlators/cluster/dht/src/dht-rebalance.c b/xlators/cluster/dht/src/dht-rebalance.c
index d0f49d2..291b557 100644
--- a/xlators/cluster/dht/src/dht-rebalance.c
+++ b/xlators/cluster/dht/src/dht-rebalance.c
@@ -880,8 +880,12 @@ __dht_check_free_space (xlator_t *this, xlator_t *to, xlator_t *from, loc_t *loc
dict_t *xdata = NULL;
dht_layout_t *layout = NULL;
uint64_t src_statfs_blocks = 1;
+ uint64_t src_total_blocks = 0;
uint64_t dst_statfs_blocks = 1;
- double post_availspacepercent = 0;
+ uint64_t dst_total_blocks = 0;
+ uint64_t file_blocks = 0;
+ double dst_post_availspacepercent = 0;
+ double src_post_availspacepercent = 0;
xdata = dict_new ();
if (!xdata) {
@@ -926,8 +930,24 @@ __dht_check_free_space (xlator_t *this, xlator_t *to, xlator_t *from, loc_t *loc
}
gf_msg_debug (this->name, 0, "min_free_disk - %f , block available - %lu ,"
- " block size - %lu ", conf->min_free_disk, dst_statfs.f_bavail,
- dst_statfs.f_bsize);
+ " block size - %lu ", conf->min_free_disk,
+ dst_statfs.f_bavail, dst_statfs.f_frsize);
+
+ dst_statfs_blocks = ((dst_statfs.f_bavail *
+ dst_statfs.f_frsize) /
+ GF_DISK_SECTOR_SIZE);
+
+ src_statfs_blocks = ((src_statfs.f_bavail *
+ src_statfs.f_frsize) /
+ GF_DISK_SECTOR_SIZE);
+
+ dst_total_blocks = ((dst_statfs.f_blocks *
+ dst_statfs.f_frsize) /
+ GF_DISK_SECTOR_SIZE);
+
+ src_total_blocks = ((src_statfs.f_blocks *
+ src_statfs.f_frsize) /
+ GF_DISK_SECTOR_SIZE);
/* if force option is given, do not check for space @ dst.
* Check only if space is avail for the file */
@@ -940,17 +960,22 @@ __dht_check_free_space (xlator_t *this, xlator_t *to, xlator_t *from, loc_t *loc
subvol gains certain 'blocks' of free space. A valid check is
necessary here to avoid errorneous move to destination where
the space could be scantily available.
+ With heterogenous brick support, an actual space comparison could
+ prevent any files being migrated to newly added bricks if they are
+ smaller then the free space available on the existing bricks.
*/
if (stbuf) {
- dst_statfs_blocks = ((dst_statfs.f_bavail *
- dst_statfs.f_bsize) /
- GF_DISK_SECTOR_SIZE);
- src_statfs_blocks = ((src_statfs.f_bavail *
- src_statfs.f_bsize) /
- GF_DISK_SECTOR_SIZE);
- if ((dst_statfs_blocks) <
- (src_statfs_blocks + stbuf->ia_blocks)) {
+ file_blocks = stbuf->ia_size + GF_DISK_SECTOR_SIZE - 1;
+ file_blocks /= GF_DISK_SECTOR_SIZE;
+ src_post_availspacepercent =
+ (((src_statfs_blocks + file_blocks) * 100) /
+ src_total_blocks);
+
+ dst_post_availspacepercent = ((dst_statfs_blocks * 100) /
+ dst_total_blocks);
+
+ if (dst_post_availspacepercent < src_post_availspacepercent) {
gf_msg (this->name, GF_LOG_WARNING, 0,
DHT_MSG_MIGRATE_FILE_FAILED,
"data movement of file "
@@ -969,16 +994,18 @@ __dht_check_free_space (xlator_t *this, xlator_t *to, xlator_t *from, loc_t *loc
}
}
-
check_avail_space:
if (conf->disk_unit == 'p' && dst_statfs.f_blocks) {
- post_availspacepercent = (dst_statfs.f_bavail * 100) / dst_statfs.f_blocks;
+ dst_post_availspacepercent =
+ (dst_statfs_blocks) / dst_total_blocks;
+
gf_msg_debug (this->name, 0, "file : %s, post_availspacepercent : %lf "
"f_bavail : %lu min-free-disk: %lf", loc->path,
- post_availspacepercent, dst_statfs.f_bavail, conf->min_free_disk);
+ dst_post_availspacepercent, dst_statfs.f_bavail,
+ conf->min_free_disk);
- if (post_availspacepercent < conf->min_free_disk) {
+ if (dst_post_availspacepercent < conf->min_free_disk) {
gf_msg (this->name, GF_LOG_WARNING, 0, 0,
"Write will cross min-free-disk for "
"file - %s on subvol - %s. Looking "
--
1.8.3.1