Fix CLUSTER SHARDS showing empty hostname (#11297)

* Fix CLUSTER SHARDS showing empty hostname

In #10290, we changed clusterNode hostname from `char*`
to `sds`, and the old `node->hostname` was changed to
`sdslen(node->hostname)!=0`.

But in `addNodeDetailsToShardReply` it is missing.
It results in the return of an empty string hostname
in CLUSTER SHARDS command if it unavailable.

Like this (note that we listed it as optional in the doc):
```
 9) "hostname"
10) ""
```
This commit is contained in:
Binbin 2022-09-23 02:39:34 +08:00 committed by GitHub
parent 6e993a5dfa
commit 1de675b3d5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -5040,7 +5040,11 @@ void addNodeToNodeReply(client *c, clusterNode *node) {
if (server.cluster_preferred_endpoint_type == CLUSTER_ENDPOINT_TYPE_IP) { if (server.cluster_preferred_endpoint_type == CLUSTER_ENDPOINT_TYPE_IP) {
addReplyBulkCString(c, node->ip); addReplyBulkCString(c, node->ip);
} else if (server.cluster_preferred_endpoint_type == CLUSTER_ENDPOINT_TYPE_HOSTNAME) { } else if (server.cluster_preferred_endpoint_type == CLUSTER_ENDPOINT_TYPE_HOSTNAME) {
addReplyBulkCString(c, sdslen(node->hostname) != 0 ? node->hostname : "?"); if (sdslen(node->hostname) != 0) {
addReplyBulkCBuffer(c, node->hostname, sdslen(node->hostname));
} else {
addReplyBulkCString(c, "?");
}
} else if (server.cluster_preferred_endpoint_type == CLUSTER_ENDPOINT_TYPE_UNKNOWN_ENDPOINT) { } else if (server.cluster_preferred_endpoint_type == CLUSTER_ENDPOINT_TYPE_UNKNOWN_ENDPOINT) {
addReplyNull(c); addReplyNull(c);
} else { } else {
@ -5066,7 +5070,7 @@ void addNodeToNodeReply(client *c, clusterNode *node) {
&& sdslen(node->hostname) != 0) && sdslen(node->hostname) != 0)
{ {
addReplyBulkCString(c, "hostname"); addReplyBulkCString(c, "hostname");
addReplyBulkCString(c, node->hostname); addReplyBulkCBuffer(c, node->hostname, sdslen(node->hostname));
length++; length++;
} }
setDeferredMapLen(c, deflen, length); setDeferredMapLen(c, deflen, length);
@ -5122,9 +5126,9 @@ void addNodeDetailsToShardReply(client *c, clusterNode *node) {
addReplyBulkCString(c, getPreferredEndpoint(node)); addReplyBulkCString(c, getPreferredEndpoint(node));
reply_count++; reply_count++;
if (node->hostname) { if (sdslen(node->hostname) != 0) {
addReplyBulkCString(c, "hostname"); addReplyBulkCString(c, "hostname");
addReplyBulkCString(c, node->hostname); addReplyBulkCBuffer(c, node->hostname, sdslen(node->hostname));
reply_count++; reply_count++;
} }