In bash, if you put:
ls /Users/*/.ssh/id_rsa 2>&1 > rsa-keys.log
…you’re redirecting stderr to the stdout’s destination while stdout is still sending output to the screen. So any permission errors encountered will go to the screen, not to rsa-keys.log.
From the bash manpage:
==================
Note that the order of redirections is significant. For example, the command
ls > dirlist 2>&1
directs both standard output and standard error to the file dirlist, while the command
ls 2>&1 > dirlist
directs only the standard output to file dirlist, because the standard error was duplicated from the standard output before the standard output was redirected to dirlist.
==================
Commands given to the shell are evaluated and processed in a specific order and fashion, and this is one quirk of that that many people are unaware of.
IMO
|& tee dirlist
is easier to manageYour way would spawn a whole extra process, but if you’re running Bash commands I suppose that doesn’t often matter.
For
2>&1
to work don’t we need to be using some shell anyway?Yeah. The shell, plus whatever command (or commands) you tell the shell to run.
This is a Bash thing?
https://www.man7.org/linux/man-pages/man1/bash.1.html
So it is a bash thing.
Just to be clear, because some seem to conflate Bash with Shell. If not specified, assume POSIX shell, that’s how /bin/sh is handled as well. And that has no
|&
.True
But nowadays
/bin/sh
is often just a link to bashWhich puts Bash in POSIX compliance mode.
$ sh sh-5.2$ echo dfgsdfgfd |& tee /tmp/t dfgsdfgfd sh-5.2$ cat /tmp/t dfgsdfgfd sh-5.2$
¯_(ツ)_/¯