11. Job Control
Let's say you're working on a single terminal window and you're running a command that is taking forever. You can't interact with the shell until it is complete, however we want to keep working on our machines, so we need that shell open. Fortunately we can control how our processes run with jobs:
Sending a job to the background
Appending an ampersand (&) to the command will run it in the background so you can still use your shell. Let's see an example:
$ sleep 1000 &
$ sleep 1001 &
$ sleep 1002 &
View all background jobs
Now you can view the jobs you just sent to the background.
$ jobs[1] Running sleep 1000 &
[2]- Running sleep 1001 &
[3]+ Running sleep 1002 &
This will show you the job id in the first column, then the status and the command that was run. The + next to the job ID means that it is the most recent background job that started. The job with the - is the second most recent command.
Sending a job to the background on existing job
If you already ran a job and want to send it to the background, you don't have to terminate it and start over again. First suspend the job with Ctrl-Z, then run the bg command to send it to the background.
pete@icebox ~ $ sleep 1003
^Z
[4]+ Stopped sleep 1003pete@icebox ~ $ bg
[4]+ sleep 1003 &pete@icebox ~ $ jobs
[1] Running sleep 1000 &
[2] Running sleep 1001 &
[3]- Running sleep 1002 &
[4]+ Running sleep 1003 &
Moving a job from the background to the foreground
To move a job out of the background just specify the job ID you want. If you run fg without any options, it will bring back the most recent background job (the job with the + sign next to it)
$ fg %1
Kill background jobs
Similar to moving jobs out of the background, you can use the same form to kill the processes by using their Job ID.
kill %1
Exercises
Move some jobs between the background and the foreground