你是否遇到过这样的状况:从终端软件登陆远程的Linux主机,将一堆很大的文件压缩为一个.tar.gz文件,连续压缩了半个小时尚未完成,这时,忽然你断网了,你登陆不上远程Linux主机了,那么前面的半个小时就会前功尽弃,你很是气愤……linux
在Linux下,若是你要执行的shell命令耗时特别长,而且:(1)你的网络不稳定,随时可能断网;或者(2)你在执行了shell命令以后必需要关闭终端软件(例如SecureCRT)。shell
那么你就须要以脱离终端的方式在后台运行这个shell命令。bash
方法以下:服务器
(1)输入命令:网络
nohup 你的shell命令 &spa
(2)回车,使终端回到shell命令行;命令行
(3)输入exit命令退出终端:exit队列
(4)如今能够关闭你的终端软件了,等过足够的时间,让你的shell命令执行完了再上去看结果吧。进程
其中,nohup命令可让你的shell命令忽略SIGHUP信号,便可以使之脱离终端运行;“&”可让你的命令在后台运行。it
以脱离终端的方式在后台运行shell命令有这样几个好处:只要你执行过了命令,那么你的网络中断不会对你有任何影响,而且你就能够关闭终端软件了。
1、为何要使程序在后台执行
咱们计算的程序都是周期很长的,一般要几个小时甚至一个星期。咱们用的环境是用putty远程链接到日本Linux服务器。因此使程序在后台跑有如下三个好处:
1:咱们这边是否关机不影响日本那边的程序运行。(不会像之前那样,咱们这网络一断开,或一关机,程序就断掉或找不到数据,跑了几天的程序只能重头再来,非常烦恼)
2:不影响计算效率
2:让程序在后台跑后,不会占据终端,咱们能够用终端作别的事情。
2、怎么样使程序在后台执行
方法有不少,这里主要列举两种。假如咱们有程序pso.cpp,经过编译后产生可执行文件pso,咱们要使pso在linux服务器后台执行。当客户端关机后从新登入服务器后继续查看原本在终端输出的运行结果。(假设操做都在当前目录下)
方法1在终端输入命令:
# ./pso > pso.file 2>&1 &
解释:将pso直接放在后台运行,并把终端输出存放在当前目录下的pso.file文件中。
当客户端关机后从新登录服务器后,直接查看pso.file文件就可看执行结果(命
令:#cat pso.file)。
方法2在终端输入命令:
# nohup ./pso > pso.file 2>&1 &
解释:nohup就是不挂起的意思,将pso直接放在后台运行,并把终端输出存放在当前
目录下的pso.file文件中。当客户端关机后从新登录服务器后,直接查看pso.file
文件就可看执行结果(命令:#cat pso.file)。
3、经常使用任务管理命令
# jobs //查看任务,返回任务编号n和进程号
# bg %n //将编号为n的任务转后台运行
# fg %n //将编号为n的任务转前台运行
# ctrl+z //挂起当前任务
# ctrl+c //结束当前任务
注:若是要使在前天执行任务放到后台运行,则先要用ctrl+z挂起该任务,而后用bg使以后台执行。
附:
在Linux中,若是要让进程在后台运行,通常状况下,咱们在命令后面加上&便可,实际上,这样是将命令放入到一个做业队列中了:
$ ./test.sh & [1] 17208 $ jobs -l [1]+ 17208 Running ./test.sh &
对于已经在前台执行的命令,也能够从新放到后台执行,首先按ctrl+z暂停已经运行的进程,而后使用bg命令将中止的做业放到后台运行:
$ ./test.sh [1]+ Stopped ./test.sh $ bg %1 [1]+ ./test.sh & $ jobs -l [1]+ 22794 Running ./test.sh &
可是如上方到后台执行的进程,其父进程仍是当前终端shell的进程,而一旦父进程退出,则会发送hangup信号给全部子进程,子进程收到hangup之后也会退出。若是咱们要在退出shell的时候继续运行进程,则须要使用nohup忽略hangup信号,或者setsid将将父进程设为init进程(进程号为1)
$ echo $$ 21734 $ nohup ./test.sh & [1] 29016 $ ps -ef | grep test 515 29710 21734 0 11:47 pts/12 00:00:00 /bin/sh ./test.sh 515 29713 21734 0 11:47 pts/12 00:00:00 grep test
$ setsid ./test.sh & [1] 409 $ ps -ef | grep test 515 410 1 0 11:49 ? 00:00:00 /bin/sh ./test.sh 515 413 21734 0 11:49 pts/12 00:00:00 grep test
上面的试验演示了使用nohup/setsid加上&使进程在后台运行,同时不受当前shell退出的影响。那么对于已经在后台运行的进程,该怎么办呢?可使用disown命令:
$ ./test.sh & [1] 2539 $ jobs -l [1]+ 2539 Running ./test.sh & $ disown -h %1 $ ps -ef | grep test 515 410 1 0 11:49 ? 00:00:00 /bin/sh ./test.sh 515 2542 21734 0 11:52 pts/12 00:00:00 grep test
另外还有一种方法,即便将进程在一个subshell中执行,其实这和setsid殊途同归。方法很简单,将命令用括号() 括起来便可:
$ (./test.sh &) $ ps -ef | grep test 515 410 1 0 11:49 ? 00:00:00 /bin/sh ./test.sh 515 12483 21734 0 11:59 pts/12 00:00:00 grep test
注:本文试验环境为Red Hat Enterprise Linux AS release 4 (Nahant Update 5),shell为/bin/bash,不一样的OS和shell可能命令有些不同。例如AIX的ksh,没有disown,可是可使用nohup -pPID来得到disown一样的效果。
还有一种更增强大的方式是使用screen,首先建立一个断开模式的虚拟终端,而后用-r选项从新链接这个虚拟终端,在其中执行的任何命令,都能达到nohup的效果,这在有多个命令须要在后台连续执行的时候比较方便:
$ screen -dmS screen_test $ screen -list There is a screen on: 27963.screen_test (Detached) 1 Socket in /tmp/uscreens/S-jiangfeng. $ screen -r screen_test