Linux基础知识 ·

Linux后台工作管理

[隐藏]

当我们登陆系统取得 bash shell 之后,可以在单一终端机介面下同时进行多个工作的行为管理,进行工作管理的行为中, 其实每个工作都是目前 bash 的子程序,亦即彼此之间是有相关性的。 我们无法以 job control 的方式由 tty1 的环境去管理 tty2 的 bash !

当我们处于一个终端,在可以出现提示字节让你操作的环境就称为前台 (foreground),至于其他工作就可以让你放入后台 (background) 去暂停或运行。要注意的是,放入后台的工作想要运行时, 他必须不能够与使用者互动。举例来说, vim 绝对不可能在背景里面运行 (running) 的!因为你没有输入数据他就不会跑! 而且放入背景的工作是不可以使用 [ctrl]+c 来终止的』!

总之,要进行 bash 的 job control 必须要注意到的限制是:

  • 这些工作所触发的程序必须来自于你 shell 的子程序(只管理自己的 bash);
  • 前台:你可以控制与下达命令的这个环境称为前景的工作 (foreground);
  • 后台:可以自行运行的工作,你无法使用 [ctrl]+c 终止他,可使用 bg/fg 呼叫该工作;
  • 后台中『运行』的程序不能等待 terminal/shell 的输入(input)

&:将工作放入后台执行

我们在只有一个 bash 的环境下,如果想要同时进行多个工作, 那么可以将某些工作直接丢到后台环境当中,让我们可以继续操作前台的工作!那么如何将工作丢到后台最简单的方法就是利用『 & 』这个玩意儿了!

示例:将 /etc/ 整个备份成为 /tmp/etc.tar.gz 且后台执行:

在输入一个命令后,在该命令的最后面加上一个『 & 』代表将该命令丢到背景中, 此时 bash 会给予这个命令一个『工作号码(job number)』,就是那个 [1] 啦!至于后面那个 4005 则是该命令所触发的『 PID 』了!而且,我们可以继续操作 bash 呢!

完成的时候会显示“[1]+  Done ......”代表 [1] 这个工作已经完成 (Done) ,该工作的命令则是接在后面那一串命令列。 这样了解了吧!另外,这个 & 代表:『将工作丢到背景中去运行』!此外,这样的情况最大的好处是: 不怕被 [ctrl]+c 中断的啦! 此外,将工作丢到背景当中要特别注意数据的流向!包括上面的信息就有出现错误信息,导致我的前景被影响。 虽然只要按下 [enter] 就会出现提示字节。但如果我将刚刚那个命令改成:

在背景当中运行的命令,如果有 stdout 及 stderr 时,他的数据依旧是输出到萤幕上面的, 所以,我们会无法看清自己输入的字符,当然也就无法完好的掌握前台工作。同时由于是背景工作的 tar , 此时你怎么按下 [ctrl]+c 也无法停止萤幕被搞的花花绿绿的!所以,最佳的状况就是利用数据流重导向, 将输出数据传送至某个文件中。举例来说,我可以这样做:

如此一来,输出的信息都给他传送到 /tmp/log.txt 当中,当然就不会影响到我们前景的作业了。

工作号码 (job number) 只与你这个 bash 环境有关,但是他既然是个命令触发的东西,所以当然一定是一个程序, 因此你会观察到有 job number 也搭配一个 PID !

[ctrl]-z:将当前工作放入后台

例如,正在 vim 中码代码,突然又有其他事情要做,此时就可以将 vim 放入后台,而不必退出 vim 。

在 vim 的命令模式下,按下 [ctrl] 及 z 这两个按键,萤幕上会出现 [2] ,表示这是第一个工作, 而那个 + 代表最近一个被丢进背景的工作,且目前在背景下默认会被取用的那个工作 (与 fg 这个命令有关 )!而那个 Stopped 则代表目前这个工作的状态。在默认的情况下,使用 [ctrl]-z 丢到背景当中的工作都是『暂停』的状态!

jobs:查看当前后台任务

jobs 选项

常用选项:

-l :除了列出 job number 与命令串之外,同时列出 PID 的号码;

-r :仅列出正在背景 run 的工作;

-s :仅列出正在背景当中暂停 (stop) 的工作。

如果想要知道目前有多少的工作在背景当中,就用 jobs 这个命令吧!一般来说,直接下达 jobs 即可! 不过,如果你还想要知道该 job number 的 PID 号码,可以加上 -l 这个参数! 在输出的信息当中,例如上表,仔细看到那个 + - 号!那个 + 代表默认的取用工作。 所以说:『目前我有两个工作在背景当中,两个工作都是暂停的, 而如果我仅输入 fg 时,那么那个 [2] 会被拿到前景当中来处理』!

其实 + 代表最近被放到背景的工作号码, - 代表最近最后第二个被放置到背景中的工作号码。 而超过最后第三个以后的工作,就不会有 +/- 符号存在了!

fg:将后台任务切入前台

[ctrl]-z 可以将目前的工作丢到背景底下去『暂停』,而 fg 命令则可以将后台任务切入前台来执行了。

fg %jobnumber

%jobnumber :jobnumber 为工作号码(数字)。注意,那个 % 是可有可无的!

若不加任务工作号码,则默认取出最近的任务,也就是带+的。

经过 fg 命令就能够将后台工作拿到前台来处理!

bg:运行后台任务

[ctrl]-z 可以将目前的工作丢到背景底下去『暂停』,而 bg 命令则可以让后台暂停的任务执行了。

bg %jobnumber

%jobnumber :jobnumber 为工作号码(数字)。注意,那个 % 是可有可无的!

看到哪里有差异吗?呼呼!没错!就是那个状态列~由 Stopping 变成了 Running !命令列最后方多了一个 & 的符号就代表该工作被启动在背景当中了!

kill %jobnumber:管理后台任务

刚刚我们可以让一个已经在背景当中的工作继续工作,也可以让该工作以 fg 拿到前景来, 那么,如果想要将该工作直接移除呢?或者是将该工作重新启动呢?这个时候就得需要给予该工作一个讯号 (signal) ,让他知道该怎么作才好!此时, kill 这个命令就派上用场啦!

特别留意一下, -9 这个 signal 通常是用在『强制删除一个不正常的工作』时所使用的, -15 则是以正常步骤结束一项工作(15也是默认值),两者之间并不相同呦!举上面的例子来说, 我用 vi 的时候,不是会产生一个 .filename.swp 的文件吗? 那么,当使用 -15 这个 signal 时, vi 会尝试以正常的步骤来结束掉该 vi 的工作, 所以 .filename.swp 会主动的被移除。但若是使用 -9 这个 signal 时,由于该 vi 工作会被强制移除掉,因此, .filename.swp 就会继续存在文件系统当中。

另外, kill 后面接的数字默认会是 PID ,如果想要管理 bash 的工作控制,就得要加上 %数字 了, 这点也得特别留意才行!

离线执行任务

要注意的是,我们在工作管理当中提到的『背景』指的是在终端机模式下可以避免 [crtl]-c 中断的一个情境, 并不是放到系统的背景去!所以,工作管理的背景依旧与终端机有关啦! 在这样的情况下,如果你是以远程连线方式连接到你的 Linux 主机,并且将工作以 & 的方式放到背景去, 请问,在工作尚未结束的情况下你离线了,该工作还会继续进行吗?答案是『否』!不会继续进行,而是会被中断掉。

那怎么办?如果我的工作需要进行一大段时间,我又不能放置在背景底下,那该如何处理呢? 首先,你可以使用 at 来处理即可!因为 at 是将工作放置到系统背景, 而与终端机无关。如果不想要使用 at 的话,那你也可以尝试使用 nohup 这个命令来处理!这个 nohup 可以让你在离线或注销系统后,还能够让工作继续进行。他的语法有点像这样:

很简单的命令吧!上述命令需要注意的是, nohup 并不支持 bash 内建的命令,因此你的命令必须要是外部命令才行。

如果你想要让在背景的工作在你注销后还能够继续的运行,那么使用 nohup 搭配 & 。

参与评论