服务器后台运行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
经验分享 程序员 微信小程序 职场和发展