diff options
| author | Amar Tumballi <amarts@redhat.com> | 2013-09-10 15:21:45 +0530 | 
|---|---|---|
| committer | Vijay Bellur <vbellur@redhat.com> | 2013-09-10 09:05:18 -0700 | 
| commit | 9d4ea7a870668d9af9bbd415ff9ad3aace59e170 (patch) | |
| tree | e08a44da52b178b37d8a9063857ea9776ce0ef82 /xlators/cluster/dht/src/switch.c | |
| parent | f43a223ad1e53041f46b351aa260203ea0685613 (diff) | |
cluster/dht: Ignore subvols with error in min-free-disk/inodes
Currently when selecting a alternative subvolume when hashed
subvol has exceeded min-free-disk/inodes, we do not check if
layouts have errors (including decommissioning). This leads
to data being written to those subvolumes, and in case of
decommissioning, will lead to data loss.
BUG: 982919
> Original-Author: shishir gowda <sgowda@redhat.com>
> Reviewed-on: http://review.gluster.org/5299
Change-Id: If301a86cf3ca5fad6529bd2e61382f9901663ba0
Signed-off-by: Amar Tumballi <amarts@redhat.com>
Reviewed-on: http://review.gluster.org/5888
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Vijay Bellur <vbellur@redhat.com>
Diffstat (limited to 'xlators/cluster/dht/src/switch.c')
| -rw-r--r-- | xlators/cluster/dht/src/switch.c | 6 | 
1 files changed, 4 insertions, 2 deletions
| diff --git a/xlators/cluster/dht/src/switch.c b/xlators/cluster/dht/src/switch.c index 6ec343102b6..e05d6ee6749 100644 --- a/xlators/cluster/dht/src/switch.c +++ b/xlators/cluster/dht/src/switch.c @@ -434,7 +434,8 @@ switch_create (call_frame_t *frame, xlator_t *this,          avail_subvol = get_switch_matching_subvol (loc->path, conf, subvol);          if (dht_is_subvol_filled (this, avail_subvol)) {                  avail_subvol = -                        dht_free_disk_available_subvol (this, avail_subvol); +                        dht_free_disk_available_subvol (this, avail_subvol, +                                                        local);          }          if (subvol != avail_subvol) { @@ -534,7 +535,8 @@ switch_mknod (call_frame_t *frame, xlator_t *this, loc_t *loc, mode_t mode,          avail_subvol = get_switch_matching_subvol (loc->path, conf, subvol);          if (dht_is_subvol_filled (this, avail_subvol)) {                  avail_subvol = -                        dht_free_disk_available_subvol (this, avail_subvol); +                        dht_free_disk_available_subvol (this, avail_subvol, +                                                        local);          }          if (avail_subvol != subvol) { | 
