转自:http://zeldor.biz/2010/07/what-does-this-“-devnull-21″-mean/
I remember being very confused for a very long time about the trailing garbage in commands that I saw in Linux systems.
Now I can explain it to you with a very easy example.
Standard in, out, and error
There are 3 standard sources of input and output for a program. Standard input usually comes from the keyboard if it’s an interactive program, or from another program if it’s processing the other program’s output. The program usually prints to standard output, and sometimes prints to standard error. These three file descriptors (you can think of them as “data pipes”) are often called STDIN, STDOUT and STDERR
Sometimes they’re not named, they’re numbered! The built-in numberings for them are 0, 1, and 2, in that order. By default, if you don’t name or number one explicitly, you’re talking about STDOUT.
Given that context, you can see the command above is redirecting standard output into /dev/null, which is a place you can dump anything you don’t want (often called the bit-bucket), then redirecting standard error into standard output (you have to put an & in front of the destination when you do this).
Will create a new directory
1 | mkdir test |
if you execute it second time you will get a error.
With this redirection you will suppress the error.
1 | mkdir test > /dev/null 2>&1 |
The short explanation, therefore, is “all output from this command should be shoved into a black hole.” That’s one good way to make a program be really quiet! That means, if you have some critical errors in your code, you will never see them.