diff options
| author | shishir gowda <shishirng@gluster.com> | 2012-02-17 19:21:07 +0530 | 
|---|---|---|
| committer | Vijay Bellur <vijay@gluster.com> | 2012-02-19 04:47:50 -0800 | 
| commit | 4a65356275cda45f665dfa99d3712f6fb9087aff (patch) | |
| tree | 43a58dd347e770073d26c13fd54522e3825d957b /libglusterfs/src/xlator.c | |
| parent | 6123265556e54891369cc79a72b670a4b23a8a41 (diff) | |
cluster/dht: Support for hardlink rebalance when decommissioning
The support for hardlink rebalance is only available for decommissioning
of a node. this can be triggered in two ways
1. remove-brick start
2. if decommission node value is set in vol file, then a normal rebalance
   command
The way we handle it is-
if (nlink > 1)
do
       * if src file doesnt have linkto xattr
                * mark src's linkto to the dst
       * else
                * perform a link on the dst
                * do a look up
                * if nlinks = dst.nlinks
                        * migrate data
                * else
                        * continue crawling
done
Signed-off-by: shishir gowda <shishirng@gluster.com>
Change-Id: If43b5524b872fd1413e9f7aa7f436cb244e30d8d
BUG: 763844
Reviewed-on: http://review.gluster.com/2737
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Amar Tumballi <amarts@redhat.com>
Diffstat (limited to 'libglusterfs/src/xlator.c')
| -rw-r--r-- | libglusterfs/src/xlator.c | 3 | 
1 files changed, 2 insertions, 1 deletions
diff --git a/libglusterfs/src/xlator.c b/libglusterfs/src/xlator.c index 428357633af..01475f5a1c3 100644 --- a/libglusterfs/src/xlator.c +++ b/libglusterfs/src/xlator.c @@ -567,7 +567,8 @@ loc_copy (loc_t *dst, loc_t *src)          if (src->parent)                  dst->parent = inode_ref (src->parent); -        dst->path = gf_strdup (src->path); +        if (src->path) +                dst->path = gf_strdup (src->path);          if (!dst->path)                  goto out;  | 
