First of all; once you've started a process, you can background it by first stopping it (hit Ctrl-Z) and then typing bg
to let it resume in the background. It's now a "job", and its stdout
/stderr
/stdin
are still connected to your terminal.
You can start a process as backgrounded immediately by appending a "&" to the end of it:
firefox &
To run it in the background silenced, use this:
firefox </dev/null &>/dev/null &
Some additional info:
nohup
is a program you can use to run your application with such that its stdout/stderr can be sent to a file instead and such that closing the parent script won't SIGHUP the child. However, you need to have had the foresight to have used it before you started the application. Because of the way nohup
works, you can't just apply it to a running process.
disown
is a bash builtin that removes a shell job from the shell's job list. What this basically means is that you can't use fg
, bg
on it anymore, but more importantly, when you close your shell it won't hang or send a SIGHUP
to that child anymore. Unlike nohup
, disown
is used after the process has been launched and backgrounded.
What you can't do, is change the stdout/stderr/stdin of a process after having launched it. At least not from the shell. If you launch your process and tell it that its stdout is your terminal (which is what you do by default), then that process is configured to output to your terminal. Your shell has no business with the processes' FD setup, that's purely something the process itself manages. The process itself can decide whether to close its stdout/stderr/stdin or not, but you can't use your shell to force it to do so.
To manage a background process' output, you have plenty of options from scripts, "nohup" probably being the first to come to mind. But for interactive processes you start but forgot to silence (firefox < /dev/null &>/dev/null &
) you can't do much, really.
I recommend you get GNU screen
. With screen you can just close your running shell when the process' output becomes a bother and open a new one (^Ac
).
Oh, and by the way, don't use "$@
" where you're using it.
$@
means, $1
, $2
, $3
..., which would turn your command into:
gnome-terminal -e "vim $1" "$2" "$3" ...
That's probably not what you want because -e only takes one argument. Use $1
to show that your script can only handle one argument.
It's really difficult to get multiple arguments working properly in the scenario that you gave (with the gnome-terminal -e
) because -e
takes only one argument, which is a shell command string. You'd have to encode your arguments into one. The best and most robust, but rather cludgy, way is like so:
gnome-terminal -e "vim $(printf "%q " "$@")"
Your use case does not describe complete detachment, per se. – jiggunjer – 2016-08-25T17:24:27.977
1That, too, is a good question. I think it's fair to consider Bash a programming language - although indeed the scope of this question is probably more on the sysadmin side... – None – 2009-03-23T12:26:38.597
This is a duplicate of this question http://stackoverflow.com/questions/285015/linux-prevent-a-background-process-from-being-stopped-after-closing-ssh-client
– Dana the Sane – 2009-03-23T13:11:50.423dup of:http://superuser.com/questions/177218/how-to-start-gui-linux-programs-from-the-command-line-but-separate-from-the-comm
– behrooz – 2011-04-25T18:07:43.273