Tworzę kopię zapasową skryptu dla ldap. Chcę, aby błędy trafiły do pliku w / var / log, a dane wyjściowe do innego pliku w folderze kopii zapasowej. Obecnie przekierowuję do pliku tymczasowego, a następnie wysyłam plik tymczasowy do dziennika. Wolałbym to zrobić jako 1 liniowiec ...
/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
Jakieś pomysły na przekierowanie stderr i stdout do różnych rur w celu skondensowania tego polecenia w 1 linii? Czy jest jakiś lepszy sposób?
Odpowiedzi:
Jak wskazano w tej odpowiedzi w Unix SE:
MyWeirdCommand.sh
testRedirection.sh:
Zyski z pracy:
stderr.log
6
stdout.log
1
źródło
W Bash możesz użyć zastępowania procesów, aby zarządzać dodatkowymi deskryptorami plików. Może się to wydawać nieco ładniejsze niż metoda zamiany deskryptorów plików.
Twoje polecenie może wyglądać mniej więcej tak:
źródło
>(process)
notacji?Oto jak wypisuję stdout i stderr do oddzielnych plików ze znacznikami czasu (przesyłanie do ts z pakietu moreutils Debiana):
PS, jeśli nie masz ts, stwórz własny alias:
źródło