diff options
Diffstat (limited to 'xlators/mgmt/glusterd/src/glusterd-brick-ops.c')
| -rw-r--r-- | xlators/mgmt/glusterd/src/glusterd-brick-ops.c | 47 | 
1 files changed, 44 insertions, 3 deletions
| diff --git a/xlators/mgmt/glusterd/src/glusterd-brick-ops.c b/xlators/mgmt/glusterd/src/glusterd-brick-ops.c index bc025caa320..0167992ba56 100644 --- a/xlators/mgmt/glusterd/src/glusterd-brick-ops.c +++ b/xlators/mgmt/glusterd/src/glusterd-brick-ops.c @@ -1470,6 +1470,8 @@ glusterd_op_remove_brick (dict_t *dict, char **op_errstr)          glusterd_brickinfo_t    *tmp           = NULL;          char                    *task_id_str   = NULL;          xlator_t                *this          = NULL; +        dict_t                  *bricks_dict   = NULL; +        char                    *brick_tmpstr  = NULL;          this = THIS;          GF_ASSERT (this); @@ -1510,9 +1512,14 @@ glusterd_op_remove_brick (dict_t *dict, char **op_errstr)                  }          } -        /* Clear task-id on commmitting/stopping of remove-brick operation */ -        if ((cmd != GF_OP_CMD_START) || (cmd != GF_OP_CMD_STATUS)) +        /* Clear task-id, rebal.op and stored bricks on commmitting/stopping +         * remove-brick */ +        if ((cmd != GF_OP_CMD_START) || (cmd != GF_OP_CMD_STATUS)) {                  uuid_clear (volinfo->rebal.rebalance_id); +                volinfo->rebal.op = GD_OP_NONE; +                dict_unref (volinfo->rebal.dict); +                volinfo->rebal.dict = NULL; +        }          ret = -1;          switch (cmd) { @@ -1595,7 +1602,20 @@ glusterd_op_remove_brick (dict_t *dict, char **op_errstr)                  goto out;          } - +        /* Save the list of bricks for later usage. Right now this is required +         * for displaying the task parameters with task status in volume status. +         */ +        bricks_dict = dict_new (); +        if (!bricks_dict) { +                ret = -1; +                goto out; +        } +        ret = dict_set_int32 (bricks_dict, "count", count); +        if (ret) { +                gf_log (this->name, GF_LOG_ERROR, +                        "Failed to save remove-brick count"); +                goto out; +        }          while ( i <= count) {                  snprintf (key, 256, "brick%d", i);                  ret = dict_get_str (dict, key, &brick); @@ -1605,6 +1625,21 @@ glusterd_op_remove_brick (dict_t *dict, char **op_errstr)                          goto out;                  } +                brick_tmpstr = gf_strdup (brick); +                if (!brick_tmpstr) { +                        ret = -1; +                        gf_log (this->name, GF_LOG_ERROR, +                                "Failed to duplicate brick name"); +                        goto out; +                } +                ret = dict_set_dynstr (bricks_dict, key, brick_tmpstr); +                if (ret) { +                        gf_log (this->name, GF_LOG_ERROR, +                                "Failed to add brick to dict"); +                        goto out; +                } +                brick_tmpstr = NULL; +                  ret = glusterd_op_perform_remove_brick (volinfo, brick, force,                                                          &need_rebalance);                  if (ret) @@ -1635,6 +1670,8 @@ glusterd_op_remove_brick (dict_t *dict, char **op_errstr)                          }                  }          } +        volinfo->rebal.dict = bricks_dict; +        bricks_dict = NULL;          ret = glusterd_create_volfiles_and_notify_services (volinfo);          if (ret) { @@ -1679,5 +1716,9 @@ out:          if (ret && err_str[0] && op_errstr)                  *op_errstr = gf_strdup (err_str); +        GF_FREE (brick_tmpstr); +        if (bricks_dict) +                dict_unref (bricks_dict); +          return ret;  } | 
