使用说明
当 Python 程序需要一直运行时,可以让程序在后台运行并将运行信息输出到日志文件中。
启动命令
一般使用
$ nohup python -u ***.py > log.log 2>&1 &
只记录异常日志
$ nohup python -u ***.py >/dev/null 2>error.log 2>&1 &
不记录任何日志
$ nohup python -u Job.py >/dev/null 2>&1 &
命令说明
“nohup” :保证程序不被挂起
“python”:是执行python代码的命令
“-u”:表示不启用缓存,实时输出打印信息到日志文件(如果不加-u,则会导致日志文件不会实时刷新代码中的print函数的信息)
“***.py”:是python的源代码文件
“log.log”:是输出的日志文件
“>”:是指将打印信息指定到日志文件
“2>&1”:将标准错误输出转变化标准输出,可以将错误信息也输出到日志文件中(0-> stdin, 1->stdout, 2->stderr)
关闭命令
查看进程
$ ps -ef|grep python
或者
$ ps -ef|grep ***
关闭进程
$ kill -9 pid号
(1) 使用 jobs 命令,具体如下:
[root@localhost test]# jobs
[4]+ Running nohup python3 -u mytest.py > mytest_out.out 2>&1 &
1
2
(2) 使用 ps -ef|grep python 或者 ps -ef|grep Job 命令,查看进程。
# ps -ef|grep python
或者
# ps -ef|grep Job
(3) 使用 ps aux 命令,查看程序的进程号。
[root@localhost test]# ps aux
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
……
root 22246 0.0 0.3 125572 6304 pts/0 S 17:29 0:00 python3 -u mytest.py
……
3、关闭进程: 使用 kill -9 进程号 命令,关闭指定进程号的程序。
[root@localhost test]# kill -9 22246
1
备注: 使用 2(2) 中查看进程的命令,检查或确认进程是否真正被关闭。