|
|
e3c68b |
From 8f89aef9691b0806d7487525c6a54a1a615c8bc1 Mon Sep 17 00:00:00 2001
|
|
|
e3c68b |
From: Mohit Agrawal <moagrawal@redhat.com>
|
|
|
e3c68b |
Date: Mon, 2 Sep 2019 10:46:10 +0530
|
|
|
e3c68b |
Subject: [PATCH 293/297] glusterd: IPV6 hostname address is not parsed
|
|
|
e3c68b |
correctly
|
|
|
e3c68b |
|
|
|
e3c68b |
Problem: IPV6 hostname address is not parsed correctly in function
|
|
|
e3c68b |
glusterd_check_brick_order
|
|
|
e3c68b |
|
|
|
e3c68b |
Solution: Update the code to parse hostname address
|
|
|
e3c68b |
|
|
|
e3c68b |
> Change-Id: Ifb2f83f9c6e987b2292070e048e97eeb51b728ab
|
|
|
e3c68b |
> Fixes: bz#1747746
|
|
|
e3c68b |
> Credits: Amgad Saleh <amgad.saleh@nokia.com>
|
|
|
e3c68b |
> Signed-off-by: Mohit Agrawal <moagrawal@redhat.com>
|
|
|
e3c68b |
> (Cherry picked from commit 6563ffb04d7ba51a89726e7c5bbb85c7dbc685b5)
|
|
|
e3c68b |
> (Reviewed on upstream link https://review.gluster.org/#/c/glusterfs/+/23341/)
|
|
|
e3c68b |
|
|
|
e3c68b |
Change-Id: Ifb2f83f9c6e987b2292070e048e97eeb51b728ab
|
|
|
e3c68b |
BUG: 1750241
|
|
|
e3c68b |
Signed-off-by: Mohit Agrawal <moagrawa@redhat.com>
|
|
|
e3c68b |
Reviewed-on: https://code.engineering.redhat.com/gerrit/181185
|
|
|
e3c68b |
Tested-by: RHGS Build Bot <nigelb@redhat.com>
|
|
|
e3c68b |
Reviewed-by: Sunil Kumar Heggodu Gopala Acharya <sheggodu@redhat.com>
|
|
|
e3c68b |
---
|
|
|
e3c68b |
xlators/mgmt/glusterd/src/glusterd-volume-ops.c | 16 +++++++++++-----
|
|
|
e3c68b |
1 file changed, 11 insertions(+), 5 deletions(-)
|
|
|
e3c68b |
|
|
|
e3c68b |
diff --git a/xlators/mgmt/glusterd/src/glusterd-volume-ops.c b/xlators/mgmt/glusterd/src/glusterd-volume-ops.c
|
|
|
e3c68b |
index 1ea8ba6..076bc80 100644
|
|
|
e3c68b |
--- a/xlators/mgmt/glusterd/src/glusterd-volume-ops.c
|
|
|
e3c68b |
+++ b/xlators/mgmt/glusterd/src/glusterd-volume-ops.c
|
|
|
e3c68b |
@@ -95,6 +95,10 @@ glusterd_check_brick_order(dict_t *dict, char *err_str)
|
|
|
e3c68b |
int32_t type = GF_CLUSTER_TYPE_NONE;
|
|
|
e3c68b |
int32_t sub_count = 0;
|
|
|
e3c68b |
struct addrinfo *ai_info = NULL;
|
|
|
e3c68b |
+ char brick_addr[128] = {
|
|
|
e3c68b |
+ 0,
|
|
|
e3c68b |
+ };
|
|
|
e3c68b |
+ int addrlen = 0;
|
|
|
e3c68b |
|
|
|
e3c68b |
const char failed_string[2048] =
|
|
|
e3c68b |
"Failed to perform brick order "
|
|
|
e3c68b |
@@ -182,15 +186,17 @@ glusterd_check_brick_order(dict_t *dict, char *err_str)
|
|
|
e3c68b |
brick_list_dup = tmpptr;
|
|
|
e3c68b |
if (brick == NULL)
|
|
|
e3c68b |
goto check_failed;
|
|
|
e3c68b |
- brick = strtok_r(brick, ":", &tmpptr);
|
|
|
e3c68b |
- if (brick == NULL)
|
|
|
e3c68b |
+ tmpptr = strrchr(brick, ':');
|
|
|
e3c68b |
+ if (tmpptr == NULL)
|
|
|
e3c68b |
goto check_failed;
|
|
|
e3c68b |
- ret = getaddrinfo(brick, NULL, NULL, &ai_info);
|
|
|
e3c68b |
+ addrlen = strlen(brick) - strlen(tmpptr);
|
|
|
e3c68b |
+ strncpy(brick_addr, brick, addrlen);
|
|
|
e3c68b |
+ brick_addr[addrlen] = '\0';
|
|
|
e3c68b |
+ ret = getaddrinfo(brick_addr, NULL, NULL, &ai_info);
|
|
|
e3c68b |
if (ret != 0) {
|
|
|
e3c68b |
ret = 0;
|
|
|
e3c68b |
gf_msg(this->name, GF_LOG_ERROR, 0, GD_MSG_HOSTNAME_RESOLVE_FAIL,
|
|
|
e3c68b |
- "unable to resolve "
|
|
|
e3c68b |
- "host name");
|
|
|
e3c68b |
+ "unable to resolve host name for addr %s", brick_addr);
|
|
|
e3c68b |
goto out;
|
|
|
e3c68b |
}
|
|
|
e3c68b |
ai_list_tmp1 = MALLOC(sizeof(addrinfo_list_t));
|
|
|
e3c68b |
--
|
|
|
e3c68b |
1.8.3.1
|
|
|
e3c68b |
|