Die Mongo Shell unterstützt derzeit keinen separaten Ausgabestream für Fehler.
Haben können SERVER-18643 abonnieren, um benachrichtigt zu werden, sobald dies implementiert ist.
Behelfslösung in der obigen Ticket vorgeschlagen ist die Ausgabe in der Mongo Shell zu markieren:
...
print("<STDOUT>")
print(multiline_json)
print("</STDOUT>")
print("<STDERR>")
print(multiline_json)
print("</STDERR>")
...
Dann können Sie auf den richtigen Ausgabestrom umleiten das folgende Skript verwenden:
#!/bin/bash
COMMAND="mongo <args>"
OUTPUT=$(${COMMAND})
function STDERR {
cat - 1>&2
}
function STDFILE {
if [ -z "$1" ]; then
return
fi
cat - >> $1
}
WRITE_ERR=0;
for line in $OUTPUT; do
if [[ "$line" == "<STDERR>"* ]]; then
WRITE_ERR=1
continue
elif [[ "$line" == "</STDERR>"* ]]; then
WRITE_ERR=0
continue
fi
if [ "$WRITE_ERR" -eq "1" ]; then
printf "%s\n" "$line" | STDERR
else
printf "%s\n" "$line"
fi
done