Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Feature request for using hostname to move and connect to individual node in cluster mode #239

Open
peijiehao opened this issue Sep 6, 2024 · 6 comments

Comments

@peijiehao
Copy link

Context:

Starting from redis 7.x. two new properties cluster-preferred-endpoint-type and cluster-announce-hostname properties have been added. When cluster-preferred-endpoint-type is set to hostname, Moved and Ask responses contain the hostnames.
When cluster-announce-hostname is set, cluster nodes outputs the hostname along with the Ip. https://redis.io/docs/latest/commands/cluster-nodes/

cluster nodes output:

07c37dfeb235213a872192d90877d0cd55635b91 127.0.0.1:30004@31004,hostname4 slave e7d1eecce10fd6bb5eb35b9f99a514335d9ba9ca 0 1426238317239 4 connected

Problem:

When the nodes in the cluster have announced hostnames. hiredis-cluster should parse the hostnames instead of IPs from cluster nodes output and connect to the nodes via hostnames.
By default, hiredis-cluster runs cluster nodes and uses the IPs to make connections to the individual nodes. This integration will not work when the nodes are behind a proxy/NAT gateway, thus, we are expecting that when cluster-preferred-endpoint-type is set to hostname, on moving and connecting to a different node hiredis-cluster will use hostname instead of IP.

Solution:

Suggesting hiredis-cluster to make connections via hostnames if available and default to IPs if not present

@zuiderkwast
Copy link
Collaborator

Good point. CLUSTER SLOTS shows hostnames too when set to preferred, but there it replaces the IP if I remember correctly. Did you try to configure hiredis-cluster to use CLUSTER SLOTS instead of NODES, to check if it uses the hostnames in this case?

Regarding IP and NAT-ing, it's also possible configure the NAT-ed IP addresses using cluster-announce-ip. They will be returned to clients.

@tharunsikhinam
Copy link

tharunsikhinam commented Sep 10, 2024

Regarding IP and NAT-ing, it's also possible configure the NAT-ed IP addresses using cluster-announce-ip. They will be returned to clients.

then the assumption is the nodes can use the NAT-ed IPs for intra-cluster communication.
but that might not always be true.

redis/redis#7460 There is a feature request for what you are suggesting. but until then, having the client support hostnames gets around this issue. and these hostnames/FQDN's are mapped to the NAT-ed IP Address.

@zuiderkwast
Copy link
Collaborator

then the assumption is the nodes can use the NAT-ed IPs for intra-cluster communication.
but that might not always be true.

We're not relying on Redis updates anymore because it is no longer open source.

Valkey, the open source fork of Redis, has this new config in the upcoming 8.0 release, added in the PR valkey-io/valkey#736:

cluster-announce-client-ipv4
cluster-announce-client-ipv6

These IP addresses, if configured, will be reported to clients in CLUSTER SLOTS and similar commands, but they are not used for intra-cluster communication.

I think this is what you need in this NAT situation, right?

@zuiderkwast
Copy link
Collaborator

When cluster-preferred-endpoint-type is set to hostname, Moved and Ask responses contain the hostnames.

Yes, but when cluster-preferred-endpoint-type is set to 'ip', then MOVED and ASK return the IP, even if cluster-announce-hostname is set.

When cluster-announce-hostname is set, cluster nodes outputs the hostname along with the Ip. https://redis.io/docs/latest/commands/cluster-nodes/

cluster nodes output:

07c37dfeb235213a872192d90877d0cd55635b91 127.0.0.1:30004@31004,hostname4 slave
e7d1eecce10fd6bb5eb35b9f99a514335d9ba9ca 0 1426238317239 4 connected

...

Suggesting hiredis-cluster to make connections via hostnames if available and default to IPs if not present

I'm not sure. If we connect to a hostname but MOVED still returns IP addresses, we need to know which connection corresponds to the IP address too, so I think we should parse IP and hostname, so we can handle all possible configurations.

@bjosv Do you know if we can handle hostnames in CLUSTER SLOTS?

@tharunsikhinam
Copy link

I'm not sure. If we connect to a hostname but MOVED still returns IP addresses, we need to know which connection corresponds to the IP address too, so I think we should parse IP and hostname, so we can handle all possible configurations.

you have a point. you need both IP and hostname to handle all configurations.

and thanks for sharing valkey-io/valkey#736 , this is exactly what I was looking for !

@bjosv
Copy link
Collaborator

bjosv commented Sep 11, 2024

Enabling the client to send CLUSTER SLOTS should help you since we support hostnames in CLUSTER SLOTS.
We have this testcase testing it.

You can enable CLUSTER SLOTS with redisClusterSetOptionRouteUseSlots(cc).

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants