mirror of
https://github.com/samba-team/samba.git
synced 2024-12-23 17:34:34 +03:00
b499775527
loadconfig() currently tries to load the CTDB configuration and also any system configuration relevant to the current (event) script. Instead add a new function load_system_config() to load the distribution-specific system configuration for a component. Call this directly in the rare scripts that need the system configuration. Also call load_system_config when loading the CTDB configuration to pull in anything from the CTDB system configuration. This is partly for backward compatibility but also to get options that can be used anywhere. loadconfig() no longer takes an argument. It simply loads the CTDB configuration. Drop support for falling back to /etc/ctdb/sysconfig/ctdb (or similar). Surely there's nobody who uses that! Also, drop the indirection where loadconfig() calls _loadconfig(). This was used years ago as a test hook and is no longer required. Inexplicably, this change introduces a new shellcheck test failure, so silence this. Signed-off-by: Martin Schwenke <martin@meltin.net> Reviewed-by: Amitay Isaacs <amitay@gmail.com>
28 lines
651 B
Bash
Executable File
28 lines
651 B
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# This script can be called from a cronjob to automatically drop/release
|
|
# all public ip addresses if CTDBD has crashed or stopped running.
|
|
#
|
|
|
|
[ -n "$CTDB_BASE" ] || \
|
|
CTDB_BASE=$(d=$(dirname "$0") ; cd -P "$d" ; echo "$PWD")
|
|
|
|
. "${CTDB_BASE}/functions"
|
|
|
|
# If ctdb is running, just exit
|
|
if service ctdb status >/dev/null 2>&1 ; then
|
|
exit 0
|
|
fi
|
|
|
|
loadconfig
|
|
|
|
if [ ! -f "$CTDB_BASE/public_addresses" ] ; then
|
|
die "No public addresses file found. Can't clean up."
|
|
fi
|
|
|
|
drop_all_public_ips 2>&1 | script_log "ctdb-crash-cleanup.sh"
|
|
|
|
if [ -n "$CTDB_NATGW_PUBLIC_IP" ] ; then
|
|
drop_ip "$CTDB_NATGW_PUBLIC_IP" "ctdb-crash-cleanup.sh"
|
|
fi
|