2020-04-14 12:48:57 +02:00
|
|
|
#!/bin/bash
|
|
|
|
|
2020-05-04 07:49:30 +02:00
|
|
|
source /source_env.sh
|
|
|
|
|
2020-04-14 12:48:57 +02:00
|
|
|
# Do not attempt to write to slave
|
|
|
|
if [[ ! -z ${REDIS_SLAVEOF_IP} ]]; then
|
|
|
|
REDIS_CMDLINE="redis-cli -h ${REDIS_SLAVEOF_IP} -p ${REDIS_SLAVEOF_PORT}"
|
|
|
|
else
|
|
|
|
REDIS_CMDLINE="redis-cli -h redis -p 6379"
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Is replication active?
|
|
|
|
# grep on file is less expensive than doveconf
|
2024-02-02 17:52:41 +02:00
|
|
|
if [ -n ${MAILCOW_REPLICA_IP} ]; then
|
2020-04-14 12:48:57 +02:00
|
|
|
${REDIS_CMDLINE} SET DOVECOT_REPL_HEALTH 1 > /dev/null
|
|
|
|
exit
|
|
|
|
fi
|
|
|
|
|
|
|
|
FAILED_SYNCS=$(doveadm replicator status | grep "Waiting 'failed' requests" | grep -oE '[0-9]+')
|
|
|
|
|
|
|
|
# Set amount of failed jobs as DOVECOT_REPL_HEALTH
|
|
|
|
# 1 failed job for mailcow.local is expected and healthy
|
2020-05-04 07:49:30 +02:00
|
|
|
if [[ "${FAILED_SYNCS}" != 0 ]] && [[ "${FAILED_SYNCS}" != 1 ]]; then
|
2020-04-14 12:48:57 +02:00
|
|
|
printf "Dovecot replicator has %d failed jobs\n" "${FAILED_SYNCS}"
|
|
|
|
${REDIS_CMDLINE} SET DOVECOT_REPL_HEALTH "${FAILED_SYNCS}" > /dev/null
|
|
|
|
else
|
|
|
|
${REDIS_CMDLINE} SET DOVECOT_REPL_HEALTH 1 > /dev/null
|
|
|
|
fi
|