diff options
| author | Mohammed Rafi KC <rkavunga@redhat.com> | 2015-12-01 09:11:01 +0000 | 
|---|---|---|
| committer | Atin Mukherjee <amukherj@redhat.com> | 2015-12-08 23:16:53 -0800 | 
| commit | 28da53e26e88f23f8917810ce0177f2628aa7e9a (patch) | |
| tree | 15b3efae68d21f931051dd3fdfea1d74f83dc4ed /xlators | |
| parent | 848bf0db0dde745e1f3a966db0143b7003bd49b5 (diff) | |
tier/glusterd: Check before starting tier daemon during volume start
We start tier daemon when volume is started without looking into the
previous status. The problem with that if detach-tier is started
and then volume force start is actually starting tier daemon.
This is also fixes a problem where tier daemon is not starting
after detach stop.
Change-Id: I15b56a711e12f0e24f5ab123561258bd448621f7
BUG: 1286974
Signed-off-by: Mohammed Rafi KC <rkavunga@redhat.com>
Reviewed-on: http://review.gluster.org/12833
Tested-by: NetBSD Build System <jenkins@build.gluster.org>
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Atin Mukherjee <amukherj@redhat.com>
Diffstat (limited to 'xlators')
| -rw-r--r-- | xlators/mgmt/glusterd/src/glusterd-mgmt.c | 4 | ||||
| -rw-r--r-- | xlators/mgmt/glusterd/src/glusterd-rebalance.c | 9 | ||||
| -rw-r--r-- | xlators/mgmt/glusterd/src/glusterd-volume-ops.c | 10 | 
3 files changed, 18 insertions, 5 deletions
diff --git a/xlators/mgmt/glusterd/src/glusterd-mgmt.c b/xlators/mgmt/glusterd/src/glusterd-mgmt.c index ab706ce6cd5..575fb6fe1fe 100644 --- a/xlators/mgmt/glusterd/src/glusterd-mgmt.c +++ b/xlators/mgmt/glusterd/src/glusterd-mgmt.c @@ -400,10 +400,12 @@ gd_mgmt_v3_post_validate_fn (glusterd_op_t op, int32_t op_ret, dict_t *dict,                          }                          if (volinfo->type == GF_CLUSTER_TYPE_TIER) { -                                glusterd_defrag_info_set (volinfo, dict, +                                if (volinfo->rebal.op != GD_OP_REMOVE_BRICK) { +                                        glusterd_defrag_info_set (volinfo, dict,                                                    GF_DEFRAG_CMD_START_TIER,                                                    GF_DEFRAG_CMD_START,                                                    GD_OP_REBALANCE); +                                }                                  glusterd_restart_rebalance_for_volume (volinfo);                          }                          break; diff --git a/xlators/mgmt/glusterd/src/glusterd-rebalance.c b/xlators/mgmt/glusterd/src/glusterd-rebalance.c index bb477a7c9f2..5c5568a5d1a 100644 --- a/xlators/mgmt/glusterd/src/glusterd-rebalance.c +++ b/xlators/mgmt/glusterd/src/glusterd-rebalance.c @@ -923,6 +923,15 @@ glusterd_op_rebalance (dict_t *dict, char **op_errstr, dict_t *rsp_dict)                          goto out;                  } +                if (volinfo->type == GF_CLUSTER_TYPE_TIER && +                    cmd == GF_OP_CMD_STOP_DETACH_TIER) { +                        glusterd_defrag_info_set (volinfo, dict, +                                  GF_DEFRAG_CMD_START_TIER, +                                  GF_DEFRAG_CMD_START, +                                  GD_OP_REBALANCE); +                        glusterd_restart_rebalance_for_volume (volinfo); +                } +                  ret = 0;                  break; diff --git a/xlators/mgmt/glusterd/src/glusterd-volume-ops.c b/xlators/mgmt/glusterd/src/glusterd-volume-ops.c index beab64c23aa..4850ce64fee 100644 --- a/xlators/mgmt/glusterd/src/glusterd-volume-ops.c +++ b/xlators/mgmt/glusterd/src/glusterd-volume-ops.c @@ -2548,10 +2548,12 @@ glusterd_op_start_volume (dict_t *dict, char **op_errstr)                   * Please upgrade to version greater than GD_OP_VERSION_3_7_6                   */                  if (volinfo->type == GF_CLUSTER_TYPE_TIER) { -                        glusterd_defrag_info_set (volinfo, dict, -                                                  GF_DEFRAG_CMD_START_TIER, -                                                  GF_DEFRAG_CMD_START, -                                                  GD_OP_REBALANCE); +                        if (volinfo->rebal.op != GD_OP_REMOVE_BRICK) { +                                glusterd_defrag_info_set (volinfo, dict, +                                          GF_DEFRAG_CMD_START_TIER, +                                          GF_DEFRAG_CMD_START, +                                          GD_OP_REBALANCE); +                        }                          glusterd_restart_rebalance_for_volume (volinfo);                  }          } else {  | 
