使程序在Linux下后台运行 (关掉终端继续让程序运行的方法)

你是否遇到过这样的情况:从终端软件登录远程的Linux主机,将一堆很大的文件压缩为一个.tar.gz文件,连续压缩了半个小时还没有完成,这时,突然你断网了,你登录不上远程Linux主机了,那么前面的半个小时就会前功尽弃,你非常气愤……

在Linux下,如果你要执行的shell命令耗时特别长,并且:(1)你的网络不稳定,随时可能断网;或者(2)你在执行了shell命令之后必须要关闭终端软件(例如SecureCRT)。

 

那么你就需要以脱离终端的方式在后台运行这个shell命令。

方法如下:

(1)输入命令:

nohup 你的shell命令 &

(2)回车,使终端回到shell命令行;

(3)输入exit命令退出终端:exit

(4)现在可以关闭你的终端软件了,等过足够的时间,让你的shell命令执行完了再上去看结果吧。

其中,nohup命令可以让你的shell命令忽略SIGHUP信号,即可以使之脱离终端运行;“&”可以让你的命令在后台运行。

以脱离终端的方式在后台运行shell命令有这样几个好处:只要你执行过了命令,那么你的网络中断不会对你有任何影响,并且你就可以关闭终端软件了。

一、为什么要使程序在后台执行

我们计算的程序都是周期很长的,通常要几个小时甚至一个星期。我们用的环境是用putty远程连接到日本Linux服务器。所以使程序在后台跑有以下三个好处:

1:我们这边是否关机不影响日本那边的程序运行。(不会像以前那样,我们这网络一断开,或一关机,程序就断掉或找不到数据,跑了几天的程序只能重头再来,很是烦恼)

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)。

三、常用任务管理命令

# 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 

时间: 2024-12-28 21:11:49

使程序在Linux下后台运行 (关掉终端继续让程序运行的方法)的相关文章

求程序,linux下两个线程访问同一个全局变量,得出不同结果!

问题描述 求程序,linux下两个线程访问同一个全局变量,得出不同结果! 10C 最简单的就行,比如全局变量n=10,第一个线程输出11,第二个线程输出12.就行. 解决方案 http://bbs.chinaunix.net/thread-3773950-1-1.html 解决方案二: 定义一个全局变量,然后再线程里自增一下打印输出 解决方案三: 不同的线程 访问全局变量对变量进行不同的操作之后使用 解决方案四: 不同的线程在run()中使用的时候处理下然后再使用即可!

linux下如何编写代码用于监控特定程序的CPU,内存,磁盘和网络使用情况?

问题描述 linux下如何编写代码用于监控特定程序的CPU,内存,磁盘和网络使用情况? 初学,linux(ubuntu)环境下,如何编写代码用于监控特定程序的CPU,内存,磁盘和网络使用情况?初学者,希望从这些基础程序入手,谢谢大家~ 解决方案 读取proc下面的文件. /proc/stat 里面是CPU使用情况,/proc/meminfo里面是内存使用情况,进程信息在/proc/$pid/stat,statm里面. /proc/net/dev里面是网络使用情况,磁盘IO可以使用iostat命令

那位知道远程如何备份linux下的opends2.2里的数据,用什么方法?

问题描述 那位知道远程如何备份linux下的opends2.2里的数据,用什么方法? 那位知道远程如何备份linux下的opends2.2里的数据,用什么方法?

python获取Linux下文件版本信息、公司名和产品名的方法_python

本文实例讲述了python获取Linux下文件版本信息.公司名和产品名的方法,分享给大家供大家参考.具体如下: 区别于前文所述.本例是在linux下得到文件版本信息,主要是通过pefile模块解析文件 中的字符串得到的.代码如下: def _get_company_and_product(self, file_path): """ Read all properties of the given file return them as a dictionary. @retur

linux下通过go语言获得系统进程cpu使用情况的方法_Golang

本文实例讲述了linux下通过go语言获得系统进程cpu使用情况的方法.分享给大家供大家参考.具体分析如下: 这段代码通过linux的系统命令 ps来分析cpu的使用情况,代码如下: 复制代码 代码如下: package main import (     "bytes"     "log"     "os/exec"     "strconv"     "strings" ) type Process s

使用mina框架和nio编写的java应用程序在Linux下的限制

问题描述 之前写了一个流媒体分发的应用程序,运行在Linux下经常出现打开文件过多的问题,在修改了Linux的限制后,又经常会抛出内存溢出异常,可是使用jconsole.vm.jprofiler等工具并没有发现内存泄露.在TCP连接达到一定数量(这个数量并不大,远远没有达到mina能处理的程度)的时候就会报内存溢出,不知道是什么原因?有没有遇到过类似问题的?或对Linux了解的.帮忙分析下.

Linux下合并前缀相同的文件的程序流程及其C代码实现

一.概述 在实际的软件开发项目中,会出现对多个前缀(或后缀)相同的文件进行合并的需求.也就是说,将这些前缀(或后缀)相同的文件中的内容合并到一个文件中.这些文件的来源可能是前一流程中程序生成的文件,也可能是其他模块生成的文件. 例如,我们要将前缀相同(以"Test_"作为前缀)的Test_1.txt和Test_2.txt文件中的内容合并到ResultFile.txt文件中,如果Test_1.txt文件中的内容为: AAAAA Test_2.txt文件中的内容为: BBBBB 那么Res

Linux下error while loading shared libraries错误的解決方法

在linux下运行程序时,发现了error while loading shared libraries这种错误,一时间不知道解决办法,在网上搜索,终于解决了: ./tests: error while loading shared libraries: xxx.so.0:cannot open shared object file: No such file or directory 出现这类错误表示,系统不知道xxx.so放在哪个目录下,这时候就要在/etc/ld.so.conf中加入xxx

阿里云Linux下将网站内容从系统盘搬家到数据盘方法

最开始一看,以为很难,毕竟没有操作过,后来走了一躺,感觉也就那么回事. 阿里云系统盘和数据盘的IO性能差别 部落在网上找了一段阿里云系统盘和数据盘的IO性能差别的数据,如下: 阿里云的系统盘(20G):Total transferred 901.56Mb (15.026Mb/sec) 961.64 Requests/sec executed 阿里云的数据盘(100G):Total transferred 550Mb (9.1664Mb/sec) 586.65 Requests/sec execu