当我们在终端或控制台工作时,可能不希望由于运行一个作业而占住了屏幕,因为可能还有更重要的事情要做,比如阅读电子邮件。对于密集访问磁盘的进程,我们更希望它能够在每天的非负荷高峰时间段运行(例如凌晨)。为了使这些进程能够在后台运行,也就是说不在终端屏幕上运行,有几种选择方法可供使用。
使用&
当在前台运行某个作业时,终端被该作业占用;可以在命令后面加上&实现后台运行,例如: 1
sh test.sh &
1
command > out.file 2>&1 &
使用nohup
使用&命令后,作业被提交到后台运行,当前控制台没有被占用,但是一旦把当前控制台关掉(退出账户时),作业就会停止运行。nohup命令可以在你退出账号之后继续运行相应的进程。nohup就是不挂起的意思(no hang up),该命令的一般形式如下: 1
nohup command &
1
nohup command > myout.file 2>&1 &
使用了nohup之后,很多人就这样不管了,其实这样有可能在当前账户非正常退出或者结束的时候,命令还是自己结束了。所以在使用nohup命令后台执行命令之后,需要使用exit正常退出当前账户,这样才能保证命令一直在后台运行
相关指令
Ctrl+z
可以将一个正在执行的命令放到后台,并且处于暂停状态jobs
查看当前有多少在后台运行的命令,查看的结果是没有进程ID的,所以上面nohup打印进程ID的时候,一定要记下来,好用来结束2>&1
2>&1 是将标准出错重定向到标准输出,这里的标准输出已经重定向到了out.file文件,即将标准出错也输出到out.file文件中。最后一个&, 是让该命令在后台执行
试想2>1代表什么,2与>结合代表错误重定向,而1则代表错误重定向到一个文件1,而不代表标准输出;换成2>&1,&与1结合就代表标准输出了,就变成错误重定向到标准输出