2007-05-29 07:01:31 +04:00
#!/bin/sh
2013-10-17 09:13:21 +04:00
# Event script for ctdb-specific setup and other things that don't fit
# elsewhere.
2007-05-29 07:01:31 +04:00
2013-01-03 08:26:12 +04:00
[ -n "$CTDB_BASE" ] || \
2016-06-29 10:36:05 +03:00
CTDB_BASE=$(d=$(dirname "$0") ; cd -P "$d" ; dirname "$PWD")
. "${CTDB_BASE}/functions"
2013-01-03 08:26:12 +04:00
2018-02-20 04:56:42 +03:00
load_script_options
2007-05-29 07:01:31 +04:00
2013-06-17 04:14:24 +04:00
############################################################
2016-07-06 13:43:29 +03:00
# type is commonly supported and more portable than which(1)
# shellcheck disable=SC2039
2013-06-17 04:14:24 +04:00
select_tdb_checker ()
{
# Find the best TDB consistency check available.
use_tdb_tool_check=false
2015-06-05 17:20:59 +03:00
type tdbtool >/dev/null 2>&1 && found_tdbtool=true
type tdbdump >/dev/null 2>&1 && found_tdbdump=true
2013-06-17 04:14:24 +04:00
2015-03-19 17:30:55 +03:00
if $found_tdbtool && echo "help" | tdbtool | grep -q check ; then
use_tdb_tool_check=true
elif $found_tdbtool && $found_tdbdump ; then
2013-06-17 04:14:24 +04:00
cat <<EOF
WARNING: The installed 'tdbtool' does not offer the 'check' subcommand.
Using 'tdbdump' for database checks.
Consider updating 'tdbtool' for better checks!
EOF
2015-03-19 17:30:55 +03:00
elif $found_tdbdump ; then
2013-06-17 04:14:24 +04:00
cat <<EOF
WARNING: 'tdbtool' is not available.
Using 'tdbdump' to check the databases.
Consider installing a recent 'tdbtool' for better checks!
EOF
else
cat <<EOF
WARNING: Cannot check databases since neither
'tdbdump' nor 'tdbtool check' is available.
Consider installing tdbtool or at least tdbdump!
EOF
return 1
fi
}
check_tdb ()
{
_db="$1"
if $use_tdb_tool_check ; then
# tdbtool always exits with 0 :-(
2015-04-28 16:15:37 +03:00
if timeout 10 tdbtool "$_db" check 2>/dev/null |
2013-06-17 04:14:24 +04:00
grep -q "Database integrity is OK" ; then
return 0
else
return 1
fi
else
2015-04-28 16:15:37 +03:00
timeout 10 tdbdump "$_db" >/dev/null 2>/dev/null
2013-06-17 04:14:24 +04:00
return $?
fi
}
check_persistent_databases ()
{
2018-04-30 13:26:20 +03:00
_dir="${CTDB_DBDIR_PERSISTENT:-${CTDB_VARDIR}/persistent}"
2015-11-19 00:35:17 +03:00
[ -d "$_dir" ] || return 0
2013-06-17 04:14:24 +04:00
2016-06-29 10:54:00 +03:00
for _db in "$_dir/"*.tdb.*[0-9] ; do
[ -r "$_db" ] || continue
check_tdb "$_db" || \
die "Persistent database $_db is corrupted! CTDB will not start."
2013-06-17 04:14:24 +04:00
done
}
check_non_persistent_databases ()
{
2013-11-26 07:29:52 +04:00
_dir="${CTDB_DBDIR:-${CTDB_VARDIR}}"
2015-11-19 00:35:17 +03:00
[ -d "$_dir" ] || return 0
2013-06-17 04:14:24 +04:00
2016-06-29 10:54:00 +03:00
for _db in "${_dir}/"*.tdb.*[0-9] ; do
[ -r "$_db" ] || continue
check_tdb "$_db" || {
2018-07-19 07:43:09 +03:00
_backup="${_db}.$(date +'%Y%m%d.%H%M%S').corrupt"
2013-06-17 04:14:24 +04:00
cat <<EOF
WARNING: database ${_db} is corrupted.
Moving to backup ${_backup} for later analysis.
EOF
mv "$_db" "$_backup"
# Now remove excess backups
2016-07-12 23:53:21 +03:00
_max="${CTDB_MAX_CORRUPT_DB_BACKUPS:-10}"
_bdb="${_db##*/}" # basename
find "$_dir" -name "${_bdb}.*.corrupt" |
sort -r |
tail -n +$((_max + 1)) |
xargs rm -f
2013-06-17 04:14:24 +04:00
}
done
}
2015-02-14 04:53:08 +03:00
set_ctdb_variables ()
{
2018-02-20 10:22:33 +03:00
_f="${CTDB_BASE}/ctdb.tunables"
if [ ! -r "$_f" ] ; then
return
2015-02-14 04:53:08 +03:00
fi
2018-02-20 10:22:33 +03:00
while IFS="=" read _var _val ; do
case "$_var" in
\#*|"") continue ;;
esac
if $CTDB setvar "$_var" "$_val" ; then
echo "Set $_var to $_val"
else
echo "Invalid tunable: ${_var}=${_val}"
return 1
fi
done <"$_f"
2012-09-03 06:39:36 +04:00
}
2013-06-17 04:14:24 +04:00
############################################################
2011-08-23 10:43:53 +04:00
ctdb_check_args "$@"
2015-08-10 09:33:42 +03:00
case "$1" in
2016-07-06 07:44:14 +03:00
init)
2007-06-04 09:09:03 +04:00
# make sure we have a blank state directory for the scripts to work with
2015-08-13 08:54:20 +03:00
rm -rf "$CTDB_SCRIPT_VARDIR"
mkdir -p "$CTDB_SCRIPT_VARDIR" || \
2016-06-29 10:49:13 +03:00
die "mkdir -p ${CTDB_SCRIPT_VARDIR} - failed - $?" $?
2013-06-16 14:29:33 +04:00
2018-04-20 05:15:26 +03:00
# Load/cache database options from configuration file
ctdb_get_db_options
2013-06-17 04:14:24 +04:00
if select_tdb_checker ; then
check_persistent_databases || exit $?
check_non_persistent_databases
fi
2010-02-12 13:24:08 +03:00
;;
2007-06-04 14:05:31 +04:00
2016-07-06 07:44:14 +03:00
setup)
2013-01-08 09:49:56 +04:00
# Set any tunables from the config file
2015-02-14 04:53:08 +03:00
set_ctdb_variables || \
die "Aborting setup due to invalid configuration - fix typos, remove unknown tunables"
2007-05-30 06:27:58 +04:00
;;
2008-01-10 02:04:03 +03:00
2016-07-06 07:44:14 +03:00
startup)
2016-06-08 14:21:56 +03:00
$CTDB attach ctdb.tdb persistent
Add a configuration database, implemented as a persistent database.
This database can be used, as an option, to store
the public address assignment instead of editing the /etc/ctdb/public-addresses file manually.
This configuration is stored in one record per key, with a key-name of
public-addresses:node#<pnn>
where <pnn> is the node number.
The content of this record is the same syntax as the /etc/ctdb/public-addresses file.
When ctdbd starts, if this key exist and contains data. It is extracted from the database and compared with the normal file /etc/ctdb/public-addresses.
If the content differs, the config database "wins" and is used to overwrite/update the /etc/ctdb/public-addresses file, after which ctdbd is restarted.
The main benefit with this option is that it can be used to update the public address configuration for nodes that are offline/unreachable by updating their configuration in the persistent database.
Once the offline node is available again, it will resync its databases with the rest of the cluster, find out that the config has changed, apply the changes and restart ctdbd automatically.
The command to store the public address configuration for a node into the persistent database is :
ctdb pstore config.tdb public-addresses:node#<pnn> <filename>
where <pnn> is the node# we wish to update the config for, and <filename> is a file containing the new content for that nodes public address configuration.
(This used to be ctdb commit 292d7435a360efd7f15a7a99f658a605e07c0a81)
2010-08-25 05:37:32 +04:00
;;
2007-05-29 07:01:31 +04:00
esac
2007-06-01 14:54:26 +04:00
# all OK
exit 0