cb8e9e
From c12fb1731b7990f951d360bafe9eca49c27f5dcb Mon Sep 17 00:00:00 2001
cb8e9e
From: Dan Lambright <dlambrig@redhat.com>
cb8e9e
Date: Tue, 2 Jun 2015 18:48:19 -0400
cb8e9e
Subject: [PATCH 55/57] cluster/tier: make attach/detach work with new rebalance logic
cb8e9e
cb8e9e
This is a backport of 10795
cb8e9e
cb8e9e
The new rebalance performance improvements added new
cb8e9e
datastructures which were not initialized in the
cb8e9e
tier case. Function dht_find_local_subvol_cbk() needs
cb8e9e
to accept a list built by lower level DHT translators
cb8e9e
in order to build the local subvolumes list.
cb8e9e
cb8e9e
> Change-Id: Iab03fc8e7fadc22debc08cd5bc781b9e3e270497
cb8e9e
> BUG: 1222088
cb8e9e
> Signed-off-by: Dan Lambright <dlambrig@redhat.com>
cb8e9e
> Reviewed-on: http://review.gluster.org/10795
cb8e9e
> Tested-by: NetBSD Build System <jenkins@build.gluster.org>
cb8e9e
> Reviewed-by: Shyamsundar Ranganathan <srangana@redhat.com>
cb8e9e
cb8e9e
Change-Id: Id1fde62dce51bb91358214721b3c04ad2224c439
cb8e9e
Signed-off-by: Dan Lambright <dlambrig@redhat.com>
cb8e9e
Reviewed-on: https://code.engineering.redhat.com/gerrit/49749
cb8e9e
Tested-by: Joseph Fernandes <josferna@redhat.com>
cb8e9e
Reviewed-by: Joseph Fernandes <josferna@redhat.com>
cb8e9e
Reviewed-by: Shyam Ranganathan <srangana@redhat.com>
cb8e9e
---
cb8e9e
 xlators/cluster/dht/src/dht-common.c    |   42 +++++++++++++++++++-----------
cb8e9e
 xlators/cluster/dht/src/dht-rebalance.c |    9 +-----
cb8e9e
 2 files changed, 28 insertions(+), 23 deletions(-)
cb8e9e
cb8e9e
diff --git a/xlators/cluster/dht/src/dht-common.c b/xlators/cluster/dht/src/dht-common.c
cb8e9e
index 8870a30..868cd79 100644
cb8e9e
--- a/xlators/cluster/dht/src/dht-common.c
cb8e9e
+++ b/xlators/cluster/dht/src/dht-common.c
cb8e9e
@@ -2627,6 +2627,9 @@ dht_find_local_subvol_cbk (call_frame_t *frame, void *cookie, xlator_t *this,
cb8e9e
         int           this_call_cnt = 0;
cb8e9e
         int           ret           = 0;
cb8e9e
         char         *uuid_str      = NULL;
cb8e9e
+        char         *uuid_list     = NULL;
cb8e9e
+        char         *next_uuid_str = NULL;
cb8e9e
+        char         *saveptr       = NULL;
cb8e9e
         uuid_t        node_uuid     = {0,};
cb8e9e
 
cb8e9e
 
cb8e9e
@@ -2649,7 +2652,7 @@ dht_find_local_subvol_cbk (call_frame_t *frame, void *cookie, xlator_t *this,
cb8e9e
                         goto unlock;
cb8e9e
                 }
cb8e9e
 
cb8e9e
-                ret = dict_get_str (xattr, local->xsel, &uuid_str);
cb8e9e
+                ret = dict_get_str (xattr, local->xsel, &uuid_list);
cb8e9e
 
cb8e9e
                 if (ret < 0) {
cb8e9e
                         gf_log (this->name, GF_LOG_ERROR, "Failed to "
cb8e9e
@@ -2659,22 +2662,29 @@ dht_find_local_subvol_cbk (call_frame_t *frame, void *cookie, xlator_t *this,
cb8e9e
                         goto unlock;
cb8e9e
                 }
cb8e9e
 
cb8e9e
-                if (gf_uuid_parse (uuid_str, node_uuid)) {
cb8e9e
-                        gf_log (this->name, GF_LOG_ERROR, "Failed to parse uuid"
cb8e9e
-                                " failed for %s", prev->this->name);
cb8e9e
-                        local->op_ret = -1;
cb8e9e
-                        local->op_errno = EINVAL;
cb8e9e
-                        goto unlock;
cb8e9e
-                }
cb8e9e
+                for (uuid_str = strtok_r (uuid_list, " ", &saveptr);
cb8e9e
+                     uuid_str;
cb8e9e
+                     uuid_str = next_uuid_str) {
cb8e9e
 
cb8e9e
-                if (gf_uuid_compare (node_uuid, conf->defrag->node_uuid)) {
cb8e9e
-                        gf_log (this->name, GF_LOG_DEBUG, "subvol %s does not"
cb8e9e
-                                "belong to this node", prev->this->name);
cb8e9e
-                } else {
cb8e9e
-                        conf->local_subvols[(conf->local_subvols_cnt)++]
cb8e9e
-                                                           = prev->this;
cb8e9e
-                        gf_log (this->name, GF_LOG_DEBUG, "subvol %s belongs to"
cb8e9e
-                                " this node", prev->this->name);
cb8e9e
+                        next_uuid_str = strtok_r (NULL, " ", &saveptr);
cb8e9e
+                        if (gf_uuid_parse (uuid_str, node_uuid)) {
cb8e9e
+                                gf_log (this->name, GF_LOG_ERROR, "Failed to parse uuid"
cb8e9e
+                                        " failed for %s", prev->this->name);
cb8e9e
+                                local->op_ret = -1;
cb8e9e
+                                local->op_errno = EINVAL;
cb8e9e
+                                goto unlock;
cb8e9e
+                        }
cb8e9e
+
cb8e9e
+                        if (gf_uuid_compare (node_uuid, conf->defrag->node_uuid)) {
cb8e9e
+                                gf_log (this->name, GF_LOG_DEBUG, "subvol %s does not"
cb8e9e
+                                        "belong to this node", prev->this->name);
cb8e9e
+                        } else {
cb8e9e
+                                conf->local_subvols[(conf->local_subvols_cnt)++]
cb8e9e
+                                        = prev->this;
cb8e9e
+                                gf_log (this->name, GF_LOG_DEBUG, "subvol %s belongs to"
cb8e9e
+                                        " this node", prev->this->name);
cb8e9e
+                                break;
cb8e9e
+                        }
cb8e9e
                 }
cb8e9e
         }
cb8e9e
 
cb8e9e
diff --git a/xlators/cluster/dht/src/dht-rebalance.c b/xlators/cluster/dht/src/dht-rebalance.c
cb8e9e
index 89cc3a8..38db3a1 100644
cb8e9e
--- a/xlators/cluster/dht/src/dht-rebalance.c
cb8e9e
+++ b/xlators/cluster/dht/src/dht-rebalance.c
cb8e9e
@@ -2691,8 +2691,7 @@ gf_defrag_start_crawl (void *data)
cb8e9e
                 goto out;
cb8e9e
         }
cb8e9e
 
cb8e9e
-        if ((defrag->cmd != GF_DEFRAG_CMD_START_TIER) &&
cb8e9e
-            (defrag->cmd != GF_DEFRAG_CMD_START_LAYOUT_FIX)) {
cb8e9e
+        if (defrag->cmd != GF_DEFRAG_CMD_START_LAYOUT_FIX) {
cb8e9e
                 migrate_data = dict_new ();
cb8e9e
                 if (!migrate_data) {
cb8e9e
                         defrag->total_failures++;
cb8e9e
@@ -2789,11 +2788,7 @@ gf_defrag_start_crawl (void *data)
cb8e9e
                 }
cb8e9e
                 methods->migration_other(this, defrag);
cb8e9e
                 if (defrag->cmd == GF_DEFRAG_CMD_START_DETACH_TIER) {
cb8e9e
-                        migrate_data = dict_new ();
cb8e9e
-                        if (!migrate_data) {
cb8e9e
-                                ret = -1;
cb8e9e
-                                goto out;
cb8e9e
-                        }
cb8e9e
+
cb8e9e
                         ret = dict_set_str (migrate_data,
cb8e9e
                                             GF_XATTR_FILE_MIGRATE_KEY,
cb8e9e
                                             "force");
cb8e9e
-- 
cb8e9e
1.7.1
cb8e9e