服务器后台运行python程序
当用户注销(logout)或者网络断开时,终端会收到 HUP(hangup)信号从而关闭其所有子进程(包括sshd及其子进程)。因此,我们的解决办法就是让进程忽略 HUP 信号.
利用nohup命令将python程序放在后台运行
nohup 就是让提交的命令忽略 hangup 信号,从而当ssh连接状态断开时,不会被系统中断掉;; nohup 命令只需在要处理的命令前加上 nohup 即可,标准输出和标准错误缺省会被重定向到 nohup.out 文件中;一般可在结尾加上 & 表示将命令放入后台运行。
nohup python -u test.py > test.out 2>&1 & #或者 nohup python test.py 1>result.txt 2>error.txt & “nohup”:保证程序不被挂起 “python”:确保执行python代码 “-u”:表示不启用缓存,实时打印输出信息到日志文件(不加利用tail查看时内容不会实时刷新)也就是把输出直接放到log中,没这个参数的话,log文件的生成会有延迟 “test.py”:运行程序; “>”:将打印信息输出到日志文件; “test.out”:输出的日志文件; “2>&1”:将标准错误输出转变为标准输出,可以将错误信息也输出到日志文件中,0-> stdin, 1->stdout, 2->stderr,2与>结合代表错误重定向,而1则代表错误重定向到一个文件1,而不代表标准输出 “&”:最后一个&表示后台运行程序 > test.out 2>&1 自行更改日志输出的目录及文件filename
运行: nohup python -u xxx.py >xxx.log 2>&1 & 运行成功会输出一个PID号 如果想关闭运行程序就可以: kill -9 PID
详解: nohup指不断地运行,是no hang up的缩写,指不间断,不挂断。nohup后台运行。 python 是运行python文件 -u:python的输出又缓冲,导致xxx.log并不能够马上看到输出。-u参数,使得python不启用缓冲,可以即时看到输出。 xxx.log保存输出的信息,运行程序时会生成这个xxx文件,里面保存这输出的信息。 2>&1 将错误信息重定向到标准输出 & 最后一个&符号代表后台运行
利用ps命令查看进程:
ps -ef|grep python
利用kill命令杀死进程:
kill -9 进程序号
用top查看进程占用内存的情况:
top
利用tail命令查看日志内容:
tail -f test.out
Linux命令行下终止当前程序
在命令行下起着终止当前执行程序的作用:
Ctrl+c
相当于exit命令,退出当前shell:
Ctrl+d
挂起当前shell:
Ctrl+s
解冻挂起的shell再不行就重新连接打开一个终端,reboot linux 或 kill 相关进程:
Ctrl+q