Sunday, January 16, 2011

Is there any way to launch screen with a background process but have it not terminate when the process exits?

Launching a screen session with a background process using -d -m causes the screen session to terminate when the process exits.

Is there any way to get the screen session to stick around after the process exits, but still launch it without any user interaction?

  • Maybe if you wrap the call into a shell script, and you invoke your shell with the option to keep it running after the script is finished.

    From bandi
  • If your process can source whichever of /etc/profile or /etc/bash.bashrc and their respective $HOME files, then this might work for you:

    screen -d -m bash  --init-file background-shell-script
    

    When "background-shell-script" exits, the screen session will be sitting waiting for you at a shell prompt when you reattach with screen -r. If you reattach before the process is complete, you will see whatever output it creates as it occurs and have a shell prompt when it finishes.

    To source the normal startup files, add them at the beginning of your script:

    . /etc/profile
    # more source statements, if needed
    # do your stuff here
    
  • The key here is that you want the process to detach itself from the controlling shell or tty. The easiest way to do this is to just run nohup, i.e nohup whateverprocess. man nohup for more information.

    Its not clear why you would want the screen session to stick around after the process exits. presumably for capturing output, but that can easily be redirected.

    The only reason to use screen is if you want the process to run but it still need standard input/output for control. In any event it is advisable to avoid that if possible and just use nohup, and if its a long running process integrate it into the boot process of the machine as a long running service.

    fields : I have a few hundred of these going at once (on several machines) so any of them can be monitored as they run. Sometimes they crash out, and I want to see the last error. I dpn't want to have to manage the logfiles for the vast majority of them that run fine if I can avoid it. There's no reason to keep the output after they're done.
    From MattyB

0 comments:

Post a Comment