Я делаю резервный скрипт для ldap. Я хочу, чтобы ошибки шли в файл в / var / log, а вывод - в другой файл в папке резервной копии. В настоящее время я перенаправляю во временный файл и затем отправляю временный файл в журнал. Я бы предпочел сделать это как 1 лайнер, хотя ...
/usr/bin/ldapsearch -x -LLL -b "dc=contoso,dc=com" "(objectclass=*)" -h ldap.server -v 2>>/tmp/ldaptmp.err |
gzip -c > /mnt/backups/ldap/`date +\%Y\%m\%d`.ldif.gz ||
logger -t ldapbackup -p local6.err error exit $?
cat /tmp/ldaptmp.err | grep -v "ldap_initialize( ldap://ldap.server )" |
grep -v "filter: (objectclass=\*)" |
grep -v "requesting: All userApplication attributes" >$ERR_LOG
rm -f /tmp/ldaptmp.err
Любые идеи о том, как перенаправить stderr и stdout к различным каналам, чтобы сжать эту команду в 1 строку? Или есть лучший способ?
Ответы:
Как указано в этом ответе на Unix SE:
MyWeirdCommand.sh
testRedirection.sh:
Беговые урожаи:
stderr.log
6
stdout.log
1
источник
В Bash вы можете использовать процесс подстановки для управления дополнительными файловыми дескрипторами. Вы можете найти это немного более аккуратным, чем метод замены дескриптора файла.
Ваша команда может выглядеть примерно так:
источник
>(process)
обозначения?Вот как я печатаю stdout и stderr в отдельные файлы с временными метками (отправка по ts из пакета Debian moreutils):
PS если у вас нет ts, создайте свой собственный псевдоним:
источник