fi
p $var_mail_msg | loday -1 var_mail
- # early in install process, we dont have permission yet for exiqgrep.
- # 1100 helps allow for system restarts
- qlen=$(/usr/sbin/exiqgrep -o 1100 -c -b | awk '{print $1}') ||:
+ # Note, early in install process, we dont have permission yet for exiqgrep.
+ #
+ # todo: don't do this every 15 seconds, more like once every 2 minutes to
+ # save cpu cycles.
+ #
+ # 2400 = 40 mins. This should allow for system restarts, and
+ # 30 minute message delay plus 10 minute queu runs.
+ qlen=$(/usr/sbin/exiqgrep -o 2400 -c -b | awk '{print $1}') ||:
qmsg=
if ((qlen)); then
- qmsg="queue length $qlen"
- chars+=("q $qlen")
+ # Do sending of long delayed messages, and dont count them in our queue warnings.
+ for mid in $(exiqgrep -o 2400 -zi); do
+ if exim -Mvh $mid | awk 'tolower($2) == "fdate:"' | grep -q .; then
+ qlen=$(( qlen - 1 ))
+ if (( $(date -d "$(exim -Mset $mid -be <<<'$h_date:' | sed -n 's/^> *//;/./p')" +%s) < EPOCHSECONDS )); then
+ if ip a show veth0-mail &>/dev/null; then
+ pid=$(pgrep -f "/usr/sbin/exim4 -bd -q30m -C /etc/exim4/my.conf"|head -n1);
+ nsenter -t $pid -n -m /usr/sbin/exim4 -C /etc/exim4/my.conf -M $mid
+ else
+ /usr/sbin/exim4 -M $mid
+ fi
+ fi
+ fi
+ done
+
+ if ((qlen)); then
+ qmsg="queue length $qlen"
+ chars+=("q $qlen")
+ fi
fi
case $HOSTNAME in
# No point in emailing about the mailq on a host where we don't