#!/bin/sh # event strict to manage vsftpd in a cluster environment [ -n "$CTDB_BASE" ] || \ CTDB_BASE=$(d=$(dirname "$0") && cd -P "$d" && dirname "$PWD") . "${CTDB_BASE}/functions" service_name="vsftpd" service_reconfigure () { service $service_name restart } load_script_options ctdb_setup_state_dir "service" "$service_name" case "$1" in startup) service "$service_name" stop > /dev/null 2>&1 service "$service_name" start ctdb_counter_init ;; shutdown) service "$service_name" stop ;; takeip|releaseip) ctdb_service_set_reconfigure ;; ipreallocated) if ctdb_service_needs_reconfigure ; then ctdb_service_reconfigure fi ;; monitor) if ctdb_check_tcp_ports 21 ; then ctdb_counter_init else ctdb_counter_incr num_fails=$(ctdb_counter_get) if [ "$num_fails" -ge 2 ] ; then die "ERROR: ${num_fails} consecutive failures for vsftpd, marking node unhealthy" elif [ "$num_fails" -eq 1 ] ; then echo "WARNING: vsftpd not listening but less than 2 consecutive failures, not unhealthy yet" fi fi ;; esac exit 0