Настройте работу `cron` и mailto при ошибке, на Arch

Я использую postfix связан с коммерческим сервером SMTP для cron вакансии, чтобы отправить их владельцам по электронной почте в случае ошибки / предупреждения. Это одна из настроек Arch.

postfix работает. Так же cronie, Но хотя самая простая из всех задач cron срабатывает, я получаю электронное письмо от демона cron при каждом выполнении, которое гласит:

/ bin / sh: предупреждение: подстановка команд: игнорируется нулевой байт при вводе.

Правило cron, которое нужно запускать каждую минуту в качестве теста:

MAILTO=MYUSERNAME@LOCALHOSTNAME

* * * * * eval "export $(grep -Ez DBUS_SESSION_BUS_ADDRESS /proc/$(pgrep -u $LOGNAME gnome-session)/environ)";/home/USERNAME/test

и исполняемый файл ~/test в основном:

#!/bin/bash
/usr/bin/notify-send 'Hello world!' --icon=dialog-information

Я это понимаю grep -Ez [...] вводит нулевой байт, что необходимо при его выводе с некоторыми необычными символами.

Мой игрушечный пример работал бы правильно, если бы не это конкретное предупреждение, отправляемое по электронной почте пользователю USERNAME при каждом выполнении. Как мне избавиться от этого?

2 ответа

Решение

После некоторых исследований.... получается, что grep -Ez [...] это не правильный способ сделать это в работе cron.

/proc/[pid]/environ в ОС Linux есть особенность, заключающаяся в том, что нулевой байт является разделителем записей, поэтому его содержимое при выводе на стандартный вывод "выглядит" как одна строка, то есть без символа EOL:

$ cat -v /proc/$(pgrep -u $LOGNAME gnome-session)/environ
LC_MEASUREMENT=en_IE.UTF-8^@LC_PAPER=en_IE.UTF-8^@LC_MONETARY=en_IE.UTF-8^@LANG=en_US.UTF-8^@GDM_LANG=en_US.UTF-8^@DISPLAY=:1^@USERNAME=USERNAME^@MOZ_PLUGIN_PATH=/usr/lib/mozilla/plugins^@XDG_VTNR=2^@XDG_SESSION_ID=2^@USER=USERNAME^@DESKTOP_SESSION=gnome^@PWD=/home/USERNAME^@HOME=/home/USERNAME^@XDG_SESSION_TYPE=x11^@XDG_SESSION_DESKTOP=gnome^@LC_NUMERIC=en_IE.UTF-8^@MAIL=/var/spool/mail/USERNAME^@WINDOWPATH=2^@SHELL=/bin/bash^@XDG_CURRENT_DESKTOP=GNOME^@XDG_SEAT=seat0^@SHLVL=0^@GDMSESSION=gnome^@LOGNAME=USERNAME^@DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/1000/bus^@XDG_RUNTIME_DIR=/run/user/1000^@XAUTHORITY=/run/user/1000/gdm/Xauthority^@PATH=/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/lib/jvm/default/bin:/usr/bin/site_perl:/usr/bin/vendor_perl:/usr/bin/core_perl^@LC_TIME=en_IE.UTF-8^@

Выше я использовал cat с -v флаг, чтобы показать нуль байтов.

Таким образом, решение состоит в том, чтобы искать шаблон "DBUS_SESSION_BUS_ADDRESS" при распознавании нулевых байтов. awk а также gawk оба делают это, хотя это не переносимо, изменяя разделитель записей на шестнадцатеричный код для нулевого байта: \x00

$ awk -F 'BEGIN {RS="\x00"} /DBUS_SESSION_BUS_ADDRESS/' /proc/$(pgrep -u $LOGNAME gnome-session)/environ
DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/1000/bus

Это на самом деле производит чистый вывод без нулевых байтов и хорошо нравится cron, Предупреждение не выводится и электронное письмо не отправляется.

Замещать \0 с \n:

eval "export $(tr -s \\0 \\n </proc/$(pgrep -u $LOGNAME -x gnome-session)/environ|grep DBUS_SESSION_BUS_ADDRESS)";/usr/bin/notify-send 'Hello world!'
Другие вопросы по тегам