diff options
| author | N Balachandran <nbalacha@redhat.com> | 2017-08-16 12:58:52 +0530 | 
|---|---|---|
| committer | Raghavendra G <rgowdapp@redhat.com> | 2017-08-20 02:47:02 +0000 | 
| commit | 96b33b4b278391ca8a7755cf274931d4f1808cb5 (patch) | |
| tree | aaee51698327605c0237f4b63d1a66775f48c164 /xlators/cluster | |
| parent | 01abf7ee37702407403afcf9aa6c9019a0316e1d (diff) | |
cluster/dht: Reorder dir operations in gf_defrag_fix_layout
Earlier, rebalance performed a fix-layout on a directory
before healing its subdirectories. If there were a lot of
subdirs, it could take a while before all subdirs were
created on the newly added bricks. As dht_readdirp only lists
dirs from their hashed subvol, those dirs which hashed to
the newly added bricks but were not yet created on them were
not listed.
Now, the child dirs are listed and processed before the layout
of the parent is fixed. This introduces a change in behaviour
where files in subdirs are migrated before those in parent
directories.
Credit: Shyam <srangana@redhat.com>
Github issue: #239
Change-Id: I8ae7f24a510754cd8d1b31e5d608bcf1928599e2
BUG: 1248393
Signed-off-by: N Balachandran <nbalacha@redhat.com>
Reviewed-on: https://review.gluster.org/18045
Smoke: Gluster Build System <jenkins@build.gluster.org>
CentOS-regression: Gluster Build System <jenkins@build.gluster.org>
Reviewed-by: Raghavendra G <rgowdapp@redhat.com>
Diffstat (limited to 'xlators/cluster')
| -rw-r--r-- | xlators/cluster/dht/src/dht-rebalance.c | 147 | 
1 files changed, 71 insertions, 76 deletions
| diff --git a/xlators/cluster/dht/src/dht-rebalance.c b/xlators/cluster/dht/src/dht-rebalance.c index e20e392ceb0..101946ab386 100644 --- a/xlators/cluster/dht/src/dht-rebalance.c +++ b/xlators/cluster/dht/src/dht-rebalance.c @@ -3581,37 +3581,6 @@ gf_defrag_fix_layout (xlator_t *this, gf_defrag_info_t *defrag, loc_t *loc,                  }          } -        if ((defrag->cmd != GF_DEFRAG_CMD_START_TIER) && -            (defrag->cmd != GF_DEFRAG_CMD_START_LAYOUT_FIX)) { -                ret = gf_defrag_process_dir (this, defrag, loc, migrate_data, -                                             &perrno); - -                if (ret && (ret != 2)) { -                        if (perrno == ENOENT || perrno == ESTALE) { -                                ret = 0; -                                goto out; -                        } else { - -                                defrag->total_failures++; - -                                gf_msg (this->name, GF_LOG_ERROR, 0, -                                        DHT_MSG_DEFRAG_PROCESS_DIR_FAILED, -                                        "gf_defrag_process_dir failed for " -                                        "directory: %s", loc->path); - -                                if (conf->decommission_in_progress) { -                                        goto out; -                                } - -                                should_commit_hash = 0; -                        } -                } else if (ret == 2) { -                        should_commit_hash = 0; -                } -        } - -        gf_msg_trace (this->name, 0, "fix layout called on %s", loc->path); -          fd = fd_create (loc->inode, defrag->pid);          if (!fd) {                  gf_log (this->name, GF_LOG_ERROR, "Failed to create fd"); @@ -3635,10 +3604,10 @@ gf_defrag_fix_layout (xlator_t *this, gf_defrag_info_t *defrag, loc_t *loc,          fd_bind (fd);          INIT_LIST_HEAD (&entries.list); +          while ((ret = syncop_readdirp (this, fd, 131072, offset, &entries,                                         NULL, NULL)) != 0)          { -                  if (ret < 0) {                          if (-ret == ENOENT || -ret == ESTALE) {                                  ret = 0; @@ -3753,36 +3722,6 @@ gf_defrag_fix_layout (xlator_t *this, gf_defrag_info_t *defrag, loc_t *loc,                                                  DHT_MSG_DIR_LOOKUP_FAILED,                                                  "lookup failed for:%s",                                                  entry_loc.path); -                                        defrag->total_failures++; -                                        if (conf->decommission_in_progress) { -                                                defrag->defrag_status = -                                                GF_DEFRAG_STATUS_FAILED; -                                                ret = -1; -                                                goto out; -                                        } else { -                                                should_commit_hash = 0; -                                                continue; -                                        } -                                } -                        } - -                        ret = syncop_setxattr (this, &entry_loc, fix_layout, -                                               0, NULL, NULL); -                        if (ret) { -                                if (-ret == ENOENT || -ret == ESTALE) { -                                        gf_msg (this->name, GF_LOG_INFO, -ret, -                                                DHT_MSG_LAYOUT_FIX_FAILED, -                                                "Setxattr failed. Dir %s " -                                                "renamed or removed", -                                                entry_loc.path); -                                        ret = 0; -                                        continue; -                                } else { - -                                        gf_msg (this->name, GF_LOG_ERROR, -ret, -                                                DHT_MSG_LAYOUT_FIX_FAILED, -                                                "Setxattr failed for %s", -                                                entry_loc.path);                                          defrag->total_failures++; @@ -3792,6 +3731,7 @@ gf_defrag_fix_layout (xlator_t *this, gf_defrag_info_t *defrag, loc_t *loc,                                                  ret = -1;                                                  goto out;                                          } else { +                                                should_commit_hash = 0;                                                  continue;                                          }                                  } @@ -3823,30 +3763,85 @@ gf_defrag_fix_layout (xlator_t *this, gf_defrag_info_t *defrag, loc_t *loc,                                          continue;                                  }                          } +                } -                        if (ret != 2 && -                            gf_defrag_settle_hash (this, defrag, &entry_loc, -                            fix_layout) != 0) { -                                defrag->total_failures++; +                gf_dirent_free (&entries); +                free_entries = _gf_false; +                INIT_LIST_HEAD (&entries.list); +        } -                                gf_msg (this->name, GF_LOG_ERROR, 0, -                                        DHT_MSG_SETTLE_HASH_FAILED, -                                        "Settle hash failed for %s", -                                        entry_loc.path); +        ret = syncop_setxattr (this, loc, fix_layout, 0, NULL, NULL); +        if (ret) { +                if (-ret == ENOENT || -ret == ESTALE) { +                        gf_msg (this->name, GF_LOG_INFO, -ret, +                                DHT_MSG_LAYOUT_FIX_FAILED, +                                "Setxattr failed. Dir %s " +                                "renamed or removed", +                                loc->path); +                        ret = 0; +                } else { +                        gf_msg (this->name, GF_LOG_ERROR, -ret, +                                DHT_MSG_LAYOUT_FIX_FAILED, +                                "Setxattr failed for %s", +                                loc->path); + +                        defrag->total_failures++; +                        if (conf->decommission_in_progress) { +                                defrag->defrag_status = GF_DEFRAG_STATUS_FAILED;                                  ret = -1; +                                goto out; +                        } +                 } +        } -                                if (conf->decommission_in_progress) { -                                        defrag->defrag_status = -                                        GF_DEFRAG_STATUS_FAILED; +        if ((defrag->cmd != GF_DEFRAG_CMD_START_TIER) && +            (defrag->cmd != GF_DEFRAG_CMD_START_LAYOUT_FIX)) { +                ret = gf_defrag_process_dir (this, defrag, loc, migrate_data, +                                             &perrno); + +                if (ret && (ret != 2)) { +                        if (perrno == ENOENT || perrno == ESTALE) { +                                ret = 0; +                                goto out; +                        } else { + +                                defrag->total_failures++; +                                gf_msg (this->name, GF_LOG_ERROR, 0, +                                        DHT_MSG_DEFRAG_PROCESS_DIR_FAILED, +                                        "gf_defrag_process_dir failed for " +                                        "directory: %s", loc->path); + +                                if (conf->decommission_in_progress) {                                          goto out;                                  } + +                                should_commit_hash = 0;                          } +                } else if (ret == 2) { +                        should_commit_hash = 0; +                } +        } + +        gf_msg_trace (this->name, 0, "fix layout called on %s", loc->path); + +        if (should_commit_hash && +            gf_defrag_settle_hash (this, defrag, loc, fix_layout) != 0) { + +                defrag->total_failures++; + +                gf_msg (this->name, GF_LOG_ERROR, 0, +                        DHT_MSG_SETTLE_HASH_FAILED, +                        "Settle hash failed for %s", +                         loc->path); + +                ret = -1; + +                if (conf->decommission_in_progress) { +                        defrag->defrag_status = GF_DEFRAG_STATUS_FAILED; +                        goto out;                  } -                gf_dirent_free (&entries); -                free_entries = _gf_false; -                INIT_LIST_HEAD (&entries.list);          }          ret = 0; | 
