secureCRT断掉后想继续运行程序。也就是程序会在后台一直执行到结束。
secureCRT通过ssh联接到client端运行程序,如果关掉窗口或者断开连接时,任务会被kill。
nohup python data_combined.py
为了程序能够后台执行到结束:
1.可以用&:
比如 python test.py 改成 python test.py &
来调用执行。
2.另外,还有一种方式:通过ctrl+z、bg等一系列的命令,将已经在前台运行的作业放到后台执行:
如果一个作业已经在前台执行,可以通过ctrl+z将该作业放到后台并挂起。然后通过jobs命令查看在后台执行的作业并找到对应的作业ID,执行bg %n(n为通过jobs查到的作业ID)唤醒该作业继续执行。
该方式也存在结果会输出到终端上的情况,同样可以用重定向的方法解决 相关命令: jobs------------查看在后台执行的进程 fg %n----------将后台执行进程n调到前台执行,n表示jobnumber(通过jobs查看的进程编号,而非pid) ctrl+z----------将在前台执行的进程,放到后台并挂起 bg %n---------将在后台挂起的进程,继续执行 ctrl+c----------前台进程终止 kill %n---------杀掉后台运行的进程,n表示jobnumber(通过jobs查看的进程编号,而非pid)
但上面来两种方法只能解决disconnect时的问题。
如果关闭客户端,程序一样无法执行。当用户注销或者网络中断时,终端后收到SIGHUP信号,从而关闭其所有子进程。
这就要使用nohup执行
3.nohup命令:nohup + command
如 nohup python test.py
nohup就是不挂起的意思,nohup命令会忽略SIGHUP信号,从而终端退出时不会影响到后台作业。后台运行把终端输出存放在当前目录下的nohup.out文件中。客户端关机后重新登陆服务器可以直接查看。
4.此外还有screen命令方式也可以实现,不介绍了。
程序运行后用
ps -ef | grep '进行id'
或者ps -aux 来查看后来多少进行正在运行,grep自己的用户名,可以看到对应程序
原理如下:
在Linux/Unix中,有这样几个概念:
进程组(process group):一个或多个进程的集合,每一个进程组有唯一一个进程组ID,即进程组长进程的ID。 会话期(session):一个或多个进程组的集合,有唯一一个会话期首进程(session leader)。会话期ID为首进程的ID。 会话期可以有一个单独的控制终端(controlling terminal)。与控制终端连接的会话期首进程叫做控制进程(controlling process)。当前与终端交互的进程称为前台进程组。其余进程组称为后台进程组。 根据POSIX.1定义: 挂断信号(SIGHUP)默认的动作是终止程序。 当终端接口检测到网络连接断开,将挂断信号发送给控制进程(会话期首进程)。 如果会话期首进程终止,则该信号发送到该会话期前台进程组。 一个进程退出导致一个孤儿进程组中产生时,如果任意一个孤儿进程组进程处于STOP状态,发送SIGHUP和SIGCONT信号到该进程组中所有进程。 因此当网络断开或终端窗口关闭后,控制进程收到SIGHUP信号退出,会导致该会话期内其他进程退出。
test.py测试脚本:
[wizad@srv26 test]$ cat test.py
import time dict = {"a" : "apple", "b" : "banana", "g" : "grape", "o" : "orange"} for k in dict: print "dict[%s]="%k,dict[k] key="c" if "c" not in dict: print "it is not in %s" %key print "-------------" print dict.items() print dict.keys() print dict.values() print "-------------" iter = dict.iteritems() for it in iter: print "iteritems is:",it print type(it) print "-------------" key_iter = dict.iterkeys() for ki in key_iter: print "key_iter is",ki print type(ki) print "-------------" val_iter = dict.itervalues() for vi in val_iter: print "val_iter is",vi print type(vi) print "-------------" print "Start: %s" % time.ctime() time.sleep(20) print "End: %s" % time.ctime() f=open('result','w') f.write('this is my test for breakup, and to find whether we can finish job') time.sleep(20) f.write('/nafter we break the dialog') f.closenohup python test.py执行后。关闭客户端,重新登录后,可以查看nohup.out查看运行时屏幕输出。同时查看result看生成结果。