From 0536d7a98b832fc00d26b09c26bf14fb63dbf5fb Mon Sep 17 00:00:00 2001 From: Martin Schwenke Date: Sun, 29 Sep 2024 12:05:31 +1000 Subject: [PATCH] ctdb-common: Reimplement ctdb_sys_have_ip() using new infrastructure It can now be used when net.ipv4.ip_nonlocal_bind=1. This makes the recovery daemon's local IP verification inefficient. It can be optimised in a subsequent commit. Fall back to bind() if unable to fetch IPs. Signed-off-by: Martin Schwenke Reviewed-by: John Mulligan Reviewed-by: Anoop C S --- ctdb/common/system_socket.c | 27 +++++++++++++++++++++++---- ctdb/common/system_socket.h | 1 + 2 files changed, 24 insertions(+), 4 deletions(-) diff --git a/ctdb/common/system_socket.c b/ctdb/common/system_socket.c index 6fe4c719f00..b4275b1fc64 100644 --- a/ctdb/common/system_socket.c +++ b/ctdb/common/system_socket.c @@ -160,10 +160,7 @@ bool ctdb_sys_local_ip_check(const struct ctdb_sys_local_ips_context *ips_ctx, return false; } -/* - * See if the given IP is currently on an interface - */ -bool ctdb_sys_have_ip(const ctdb_sock_addr *_addr) +bool ctdb_sys_bind_ip_check(const ctdb_sock_addr *_addr) { int s; int ret; @@ -193,6 +190,28 @@ bool ctdb_sys_have_ip(const ctdb_sock_addr *_addr) return ret == 0; } +/* + * See if the given IP is currently on an interface + */ +bool ctdb_sys_have_ip(const ctdb_sock_addr *addr) +{ + struct ctdb_sys_local_ips_context *ips_ctx = NULL; + bool have_ip; + int ret; + + ret = ctdb_sys_local_ips_init(NULL, &ips_ctx); + if (ret != 0) { + DBG_DEBUG("Failed to get local addresses, depending on bind\n"); + have_ip = ctdb_sys_bind_ip_check(addr); + return have_ip; + } + + have_ip = ctdb_sys_local_ip_check(ips_ctx, addr); + talloc_free(ips_ctx); + + return have_ip; +} + /* * simple TCP checksum - assumes data is multiple of 2 bytes long */ diff --git a/ctdb/common/system_socket.h b/ctdb/common/system_socket.h index 3edc9e146e4..f4d092cce0a 100644 --- a/ctdb/common/system_socket.h +++ b/ctdb/common/system_socket.h @@ -30,6 +30,7 @@ int ctdb_sys_local_ips_init(TALLOC_CTX *ctx, struct ctdb_sys_local_ips_context **ips_ctx); bool ctdb_sys_local_ip_check(const struct ctdb_sys_local_ips_context *ips_ctx, const ctdb_sock_addr *addr); +bool ctdb_sys_bind_ip_check(const ctdb_sock_addr *addr); bool ctdb_sys_have_ip(const ctdb_sock_addr *addr); int ctdb_sys_send_arp(const ctdb_sock_addr *addr, const char *iface);