summaryrefslogtreecommitdiffstats
path: root/xlators/mgmt/glusterd/src/glusterd-handler.c
diff options
context:
space:
mode:
authorAmar Tumballi <amar@gluster.com>2010-09-07 09:30:29 +0000
committerVijay Bellur <vijay@dev.gluster.com>2010-09-07 09:41:22 -0700
commited561b78d9837b9f799ebb410bcc26b7e5413f33 (patch)
treea618ea9459b83d454df2dbf00b5f330fe966f51d /xlators/mgmt/glusterd/src/glusterd-handler.c
parent266df1a7d660dc0b824e6e60903536aff9242f4b (diff)
glusterd: rebalance fixes
Signed-off-by: Amar Tumballi <amar@gluster.com> Signed-off-by: Vijay Bellur <vijay@dev.gluster.com> BUG: 1481 () URL: http://bugs.gluster.com/cgi-bin/bugzilla3/show_bug.cgi?id=1481
Diffstat (limited to 'xlators/mgmt/glusterd/src/glusterd-handler.c')
-rw-r--r--xlators/mgmt/glusterd/src/glusterd-handler.c30
1 files changed, 18 insertions, 12 deletions
diff --git a/xlators/mgmt/glusterd/src/glusterd-handler.c b/xlators/mgmt/glusterd/src/glusterd-handler.c
index a2563865acd..6dee0355d3d 100644
--- a/xlators/mgmt/glusterd/src/glusterd-handler.c
+++ b/xlators/mgmt/glusterd/src/glusterd-handler.c
@@ -765,16 +765,17 @@ glusterd_defrag_start (void *data)
char cmd_str[1024] = {0,};
int ret = -1;
struct stat stbuf = {0,};
+ char value[128] = {0,};
defrag = volinfo->defrag;
if (!defrag)
goto out;
- sleep (5);
+ sleep (1);
ret = stat (defrag->mount, &stbuf);
if ((ret == -1) && (errno == ENOTCONN)) {
/* Wait for some more time before starting rebalance */
- sleep (7);
+ sleep (2);
ret = stat (defrag->mount, &stbuf);
if (ret == -1) {
volinfo->defrag_status = GF_DEFRAG_STATUS_FAILED;
@@ -785,6 +786,9 @@ glusterd_defrag_start (void *data)
}
}
+ /* Fix the root ('/') first */
+ getxattr (defrag->mount, "trusted.distribute.fix.layout", &value, 128);
+
ret = glusterd_check_and_rebalance (volinfo, defrag->mount);
/* TODO: This should run in a thread, and finish the thread when
@@ -869,7 +873,6 @@ glusterd_handle_defrag_volume (rpcsvc_request_t *req)
glusterd_volinfo_t *volinfo = NULL;
glusterd_defrag_info_t *defrag = NULL;
gf1_cli_defrag_vol_rsp rsp = {0,};
- char operation[8];
GF_ASSERT (req);
@@ -881,17 +884,17 @@ glusterd_handle_defrag_volume (rpcsvc_request_t *req)
}
switch (cli_req.cmd) {
- case GF_DEFRAG_CMD_START: strcpy (operation, "start");
- break;
- case GF_DEFRAG_CMD_STOP: strcpy (operation, "stop");
+ case GF_DEFRAG_CMD_START:
+ gf_cmd_log ("Volume rebalance"," on volname: %s "
+ "cmd: start, attempted", cli_req.volname);
break;
- case GF_DEFRAG_CMD_STATUS: strcpy (operation, "status");
+ case GF_DEFRAG_CMD_STOP:
+ gf_cmd_log ("Volume rebalance"," on volname: %s "
+ "cmd: stop, attempted", cli_req.volname);
break;
- default: strcpy (operation, "unknown");
+ default:
break;
}
- gf_cmd_log ("Volume rebalance"," on volname: %s cmd:%s attempted", cli_req.volname,
- operation);
gf_log ("glusterd", GF_LOG_NORMAL, "Received defrag volume on %s",
cli_req.volname);
@@ -975,8 +978,11 @@ glusterd_handle_defrag_volume (rpcsvc_request_t *req)
if (ret)
gf_log("glusterd", GF_LOG_DEBUG, "command: %s failed",cmd_str);
- gf_cmd_log ("volume rebalance"," on volname: %s %d %s",cli_req.volname,
- cli_req.cmd, ((ret)?"FAILED":"SUCCESS"));
+ if (cli_req.cmd != GF_DEFRAG_CMD_STATUS) {
+ gf_cmd_log ("volume rebalance"," on volname: %s %d %s",
+ cli_req.volname,
+ cli_req.cmd, ((ret)?"FAILED":"SUCCESS"));
+ }
out: