我正在为 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 行的任何想法?或者,还有更好的方法?
在 Bash 中,您可以使用进程替换来为您管理额外的文件描述符。您可能会发现这比文件描述符交换方法看起来更简洁。
您的命令可能如下所示:
正如Unix SE的这个答案所示:
MyWeirdCommand.sh
测试重定向.sh:
运行产量:
stderr.log
6
stdout.log
1
这就是我打印 stdout 和 stderr 以分隔带有时间戳的文件的方式(从 Debian moreutils 包管道到 ts ):
PS如果你没有ts,请创建自己的别名: