2

I have a process currently occupying a terminal

]$ command some_argument

I want to exit from the terminal and go home, but in the mean time I don't want to kill this running process.

For the above running process, I want to achieve something like the following:

]$ nohup command some_argument >& logfile &
iamauser
  • 329
  • 2
  • 3
  • 12
  • I started to flag this question as a dupe of [this](http://serverfault.com/questions/24425/can-i-nohup-screen-an-already-started-process/24430#24430), but the other question doesn't cover the topic of redirecting STDOUT *after* a prior backgrounding. – Andrew B Aug 21 '13 at 21:44
  • How does disown keeps a log file that this process may produce to stdout ? Please remove the duplicate that you have flagged as `disown` alone doesn't answer this question. – iamauser Aug 21 '13 at 21:48
  • 1
    I updated my question a moment ago. The short version: not really feasible, unfortunately. :( (also, I had already retracted the dupeflagging+comment before your comment hit the website) – Andrew B Aug 21 '13 at 21:49

3 Answers3

5

Disowning the process and redirecting STDOUT from an already backgrounded process isn't feasible for most users. This SO answer covers the topic pretty well.

Disassociating the process from the current shell isn't so hard: you're looking for disown. From the manpage:

SIGNALS

....

       The shell exits by default upon receipt of a SIGHUP.   Before  exiting,
       an  interactive  shell  resends  the  SIGHUP  to  all  jobs, running or
       stopped.  Stopped jobs are sent SIGCONT to ensure that they receive the
       SIGHUP.   To  prevent the shell from sending the signal to a particular
       job, it should be removed from the jobs table with the  disown  builtin
       (see  SHELL  BUILTIN  COMMANDS  below)  or marked to not receive SIGHUP
       using disown -h.

....

SHELL BUILTIN COMMANDS

....

       disown [-ar] [-h] [jobspec ...]
              Without options, each jobspec  is  removed  from  the  table  of
              active  jobs.   If jobspec is not present, and neither -a nor -r
              is supplied, the shell's notion of the current job is used.   If
              the -h option is given, each jobspec is not removed from the ta‐
              ble, but is marked so that SIGHUP is not sent to the job if  the
              shell  receives a SIGHUP.  If no jobspec is present, and neither
              the -a nor the -r option is supplied, the current job  is  used.
              If no jobspec is supplied, the -a option means to remove or mark
              all jobs; the -r option without  a  jobspec  argument  restricts
              operation  to running jobs.  The return value is 0 unless a job‐
              spec does not specify a valid job.

If you want to learn more about what nohup and disown actually do, you can check out this question. (disclaimer: shameless self-promotion)

Andrew B
  • 31,858
  • 12
  • 90
  • 128
0

I understand you are currently using a Linux based OS but for the record and in case someone happening to use Solaris 10 or newer find this page while looking for a solution, Solaris nohup implements what you are looking for:

$ command some_argument
...
^Z[1] + Stopped (SIGTSTP)        command some_argument
$ bg
[1]     command some_argument&
$ jobs -l
[1] + 1061       Running                 command some_argument
$ nohup -p 1061
Sending output to nohup.out
$ exit
jlliagre
  • 8,691
  • 16
  • 36
-1

Looks like you are close:

 nohup sh custom-script.sh > custom-out.log &

From here

TheFiddlerWins
  • 2,973
  • 1
  • 14
  • 22