|
|
14f8ab |
From 4fc0a77db5b9760fa5c00d3803c6d11a28a00b74 Mon Sep 17 00:00:00 2001
|
|
|
14f8ab |
From: Mohit Agrawal <moagrawal@redhat.com>
|
|
|
14f8ab |
Date: Wed, 3 Jul 2019 15:22:38 +0530
|
|
|
14f8ab |
Subject: [PATCH 229/255] glusterd: Show the correct brick status in get-state
|
|
|
14f8ab |
|
|
|
14f8ab |
Problem: get-state does not show correct brick status if brick
|
|
|
14f8ab |
status is not Started, it always shows started if any value
|
|
|
14f8ab |
is set brickinfo->status
|
|
|
14f8ab |
|
|
|
14f8ab |
Solution: Check the value of brickinfo->status to show correct status
|
|
|
14f8ab |
in get-state
|
|
|
14f8ab |
|
|
|
14f8ab |
> Change-Id: I12a79619024c2cf59f338220d144f2f034059b3b
|
|
|
14f8ab |
> fixes: bz#1726906
|
|
|
14f8ab |
> (Cherry pick from commit af989db23d1db00e087f2b9d3dfc43b13ef17153)
|
|
|
14f8ab |
> (Reviewed on upstream link https://review.gluster.org/#/c/glusterfs/+/22983/)
|
|
|
14f8ab |
|
|
|
14f8ab |
BUG: 1726991
|
|
|
14f8ab |
Change-Id: I12a79619024c2cf59f338220d144f2f034059b3b
|
|
|
14f8ab |
Signed-off-by: Mohit Agrawal <moagrawal@redhat.com>
|
|
|
14f8ab |
Reviewed-on: https://code.engineering.redhat.com/gerrit/175355
|
|
|
14f8ab |
Tested-by: Mohit Agrawal <moagrawa@redhat.com>
|
|
|
14f8ab |
Tested-by: RHGS Build Bot <nigelb@redhat.com>
|
|
|
14f8ab |
Reviewed-by: Atin Mukherjee <amukherj@redhat.com>
|
|
|
14f8ab |
---
|
|
|
14f8ab |
xlators/mgmt/glusterd/src/glusterd-handler.c | 7 +++++--
|
|
|
14f8ab |
xlators/mgmt/glusterd/src/glusterd-utils.c | 28 ++++++++++++++++++++++++++++
|
|
|
14f8ab |
xlators/mgmt/glusterd/src/glusterd-utils.h | 4 ++++
|
|
|
14f8ab |
3 files changed, 37 insertions(+), 2 deletions(-)
|
|
|
14f8ab |
|
|
|
14f8ab |
diff --git a/xlators/mgmt/glusterd/src/glusterd-handler.c b/xlators/mgmt/glusterd/src/glusterd-handler.c
|
|
|
14f8ab |
index cc1f1df..94e1be5 100644
|
|
|
14f8ab |
--- a/xlators/mgmt/glusterd/src/glusterd-handler.c
|
|
|
14f8ab |
+++ b/xlators/mgmt/glusterd/src/glusterd-handler.c
|
|
|
14f8ab |
@@ -5589,7 +5589,9 @@ glusterd_get_state(rpcsvc_request_t *req, dict_t *dict)
|
|
|
14f8ab |
char vol_status_str[STATUS_STRLEN] = {
|
|
|
14f8ab |
0,
|
|
|
14f8ab |
};
|
|
|
14f8ab |
-
|
|
|
14f8ab |
+ char brick_status_str[STATUS_STRLEN] = {
|
|
|
14f8ab |
+ 0,
|
|
|
14f8ab |
+ };
|
|
|
14f8ab |
this = THIS;
|
|
|
14f8ab |
GF_VALIDATE_OR_GOTO(THIS->name, this, out);
|
|
|
14f8ab |
|
|
|
14f8ab |
@@ -5852,8 +5854,9 @@ glusterd_get_state(rpcsvc_request_t *req, dict_t *dict)
|
|
|
14f8ab |
brickinfo->rdma_port);
|
|
|
14f8ab |
fprintf(fp, "Volume%d.Brick%d.port_registered: %d\n", count_bkp,
|
|
|
14f8ab |
count, brickinfo->port_registered);
|
|
|
14f8ab |
+ glusterd_brick_get_status_str(brickinfo, brick_status_str);
|
|
|
14f8ab |
fprintf(fp, "Volume%d.Brick%d.status: %s\n", count_bkp, count,
|
|
|
14f8ab |
- brickinfo->status ? "Started" : "Stopped");
|
|
|
14f8ab |
+ brick_status_str);
|
|
|
14f8ab |
|
|
|
14f8ab |
/*FIXME: This is a hacky way of figuring out whether a
|
|
|
14f8ab |
* brick belongs to the hot or cold tier */
|
|
|
14f8ab |
diff --git a/xlators/mgmt/glusterd/src/glusterd-utils.c b/xlators/mgmt/glusterd/src/glusterd-utils.c
|
|
|
14f8ab |
index 2eb5116..3bdfd49 100644
|
|
|
14f8ab |
--- a/xlators/mgmt/glusterd/src/glusterd-utils.c
|
|
|
14f8ab |
+++ b/xlators/mgmt/glusterd/src/glusterd-utils.c
|
|
|
14f8ab |
@@ -13898,6 +13898,34 @@ out:
|
|
|
14f8ab |
return ret;
|
|
|
14f8ab |
}
|
|
|
14f8ab |
|
|
|
14f8ab |
+void
|
|
|
14f8ab |
+glusterd_brick_get_status_str(glusterd_brickinfo_t *brickinfo, char *status_str)
|
|
|
14f8ab |
+{
|
|
|
14f8ab |
+ GF_VALIDATE_OR_GOTO(THIS->name, brickinfo, out);
|
|
|
14f8ab |
+ GF_VALIDATE_OR_GOTO(THIS->name, status_str, out);
|
|
|
14f8ab |
+
|
|
|
14f8ab |
+ switch (brickinfo->status) {
|
|
|
14f8ab |
+ case GF_BRICK_STOPPED:
|
|
|
14f8ab |
+ sprintf(status_str, "%s", "Stopped");
|
|
|
14f8ab |
+ break;
|
|
|
14f8ab |
+ case GF_BRICK_STARTED:
|
|
|
14f8ab |
+ sprintf(status_str, "%s", "Started");
|
|
|
14f8ab |
+ break;
|
|
|
14f8ab |
+ case GF_BRICK_STARTING:
|
|
|
14f8ab |
+ sprintf(status_str, "%s", "Starting");
|
|
|
14f8ab |
+ break;
|
|
|
14f8ab |
+ case GF_BRICK_STOPPING:
|
|
|
14f8ab |
+ sprintf(status_str, "%s", "Stopping");
|
|
|
14f8ab |
+ break;
|
|
|
14f8ab |
+ default:
|
|
|
14f8ab |
+ sprintf(status_str, "%s", "None");
|
|
|
14f8ab |
+ break;
|
|
|
14f8ab |
+ }
|
|
|
14f8ab |
+
|
|
|
14f8ab |
+out:
|
|
|
14f8ab |
+ return;
|
|
|
14f8ab |
+}
|
|
|
14f8ab |
+
|
|
|
14f8ab |
int
|
|
|
14f8ab |
glusterd_volume_get_transport_type_str(glusterd_volinfo_t *volinfo,
|
|
|
14f8ab |
char *transport_type_str)
|
|
|
14f8ab |
diff --git a/xlators/mgmt/glusterd/src/glusterd-utils.h b/xlators/mgmt/glusterd/src/glusterd-utils.h
|
|
|
14f8ab |
index 6ad8062..5c6a453 100644
|
|
|
14f8ab |
--- a/xlators/mgmt/glusterd/src/glusterd-utils.h
|
|
|
14f8ab |
+++ b/xlators/mgmt/glusterd/src/glusterd-utils.h
|
|
|
14f8ab |
@@ -781,6 +781,10 @@ glusterd_volume_get_type_str(glusterd_volinfo_t *volinfo, char **vol_type_str);
|
|
|
14f8ab |
int
|
|
|
14f8ab |
glusterd_volume_get_status_str(glusterd_volinfo_t *volinfo, char *status_str);
|
|
|
14f8ab |
|
|
|
14f8ab |
+void
|
|
|
14f8ab |
+glusterd_brick_get_status_str(glusterd_brickinfo_t *brickinfo,
|
|
|
14f8ab |
+ char *status_str);
|
|
|
14f8ab |
+
|
|
|
14f8ab |
int
|
|
|
14f8ab |
glusterd_volume_get_transport_type_str(glusterd_volinfo_t *volinfo,
|
|
|
14f8ab |
char *transport_type_str);
|
|
|
14f8ab |
--
|
|
|
14f8ab |
1.8.3.1
|
|
|
14f8ab |
|