新思想

Linux05 前台和后台

Linux 前台和后台

一、 前后台程序切换
Linux 提供了 fg 和bg 命令,让你轻松调度正在运行的任务。
假设你发现前台运行的一个程序需要很长的时间,但是需要干其他的事情,你就可以用 Ctrl-Z ,挂起这个程序,然后可以看到系统提示:
# tail -f /etc/profile
[1]+ 已停止 tail -f /etc/profile
然后我们可以把程序调度到后台执行:(bg 后面的数字为作业号)
# bg 1 # 或bg,bg后缺省数字表示直接将+号程序调度到后台执行
[1]+ tail -f /etc/profile &
用 jobs 命令查看正在运行的任务:
# jobs
[1]+ 运行中 tail -f /etc/profile &
如果想把它调回到前台运行,可以用
# fg 1 # 或fg,fg后缺省数字表示直接将+号程序调度到前台运行
tail -f /etc/profile
这样,你在控制台上就只能等待这个任务完成了。

二、后台运行命令
1. command & :后台运行,当你关掉终端,命令会停止运行
2. nohup command & :后台运行,当你关掉终端,命令仍会继续运行

& 将指令丢到后台中去执行
[ctrl]+z 将前台任务丢到后台中暂停
jobs 查看后台的工作状态
bg %jobnumber 将任务放到后台中去处理
fg %jobnumber 将后台的任务拿到前台来处理
kill 退出后台的任务

在后台运行作业时要当心:需要用户交互的命令不要放在后台执行,因为这样你的机器就会在那里傻等。不过,作业在后台运行一样会将结果输出到屏幕上,干扰你的工作。如果放在后台运行的作业会产生大量的输出,最好使用下面的方法把它的输出重定向到某个文件中:
command >out.file 2>&1 &
在上面的例子中,2>&1表示所有的标准输出和错误输出都将被重定向到一个叫做out.file 的文件中。 当你成功地提交进程以后,就会显示出一个进程号,可以用它来监控该进程,或杀死它。

三、让命令提交后不受关闭终端窗口/网络断开连接的干扰
我们知道,当用户注销(logout)或者网络断开时,终端会收到 HUP(hangup)信号从而关闭其所有子进程。因此,我们的解决办法就有两种途径:要么让进程忽略 HUP 信号,要么让进程运行在新的会话里从而成为不属于此终端的子进程。

1. nohup
nohup 无疑是我们首先想到的办法。顾名思义,nohup 的用途就是让提交的命令忽略 hangup 信号。

# nohup ping 8.8.8.8 &
[1] 1989
nohup: 忽略输入并把输出追加到"nohup.out"

# ps -ef |grep ping
root 1989 1985 0 17:43 pts/1 00:00:00 ping 8.8.8.8
root 1991 1985 0 17:44 pts/1 00:00:00 grep ping

2. setsid
nohup 无疑能通过忽略 HUP 信号来使我们的进程避免中途被中断,但如果我们换个角度思考,如果我们的进程不属于接受 HUP 信号的终端的子进程,那么自然也就不会受到 HUP 信号的影响了。setsid 就能帮助我们做到这一点。
# setsid ping 8.8.8.8 &> /dev/null

# ps -ef |grep ping
root 1989 1985 0 17:43 pts/1 00:00:00 ping 8.8.8.8
root 2012 1 0 17:49 ? 00:00:00 ping 8.8.8.8
root 2014 1985 0 17:50 pts/1 00:00:00 grep ping
值得注意的是,上例中我们的进程 ID(PID)为2012,而它的父 ID(PPID)为1(即为 init 进程 ID),并不是当前终端的进程 ID。请将此例与nohup 例中的父 ID 做比较。

3. (&)
我们知道subshell 的小技巧,将一个或多个命名包含在“()”中就能让这些命令在子 shell 中运行中,从而扩展出很多有趣的功能,我们现在要讨论的就是其中之一。
当我们将"&"也放入“()”内之后,我们就会发现所提交的作业并不在作业列表中,也就是说,是无法通过jobs来查看的。
# (ping 8.8.8.8 &> /dev/null &)
# ps -ef |grep ping
root 2037 1 0 17:55 pts/1 00:00:00 ping 8.8.8.8
root 2039 1985 0 17:55 pts/1 00:00:00 grep ping
从上例中可以看出,新提交的进程的父 ID(PPID)为1(init 进程的 PID),并不是当前终端的进程 ID。因此并不属于当前终端的子进程,从而也就不会受到当前终端的 HUP 信号的影响了。

四、tmux
我们已经知道了如何让进程免受 HUP 信号的影响,但是如果有大量这种命令需要在稳定的后台里运行,如何避免对每条命令都做这样的操作呢?
此时最方便的方法就是 tmux 了。简单的说,tmux 提供了 ANSI/VT100 的终端模拟器,使它能够在一个真实终端下运行多个全屏的伪终端。
窗口取回: tmux attach [-t session-id]

posted on 2015-11-03 18:45  新思想  阅读(242)  评论(0)    收藏  举报

导航