后台执行py文件
nohup python3 -u flask_server.py > flask_log.log 2>&1 &
1. 带&的命令行,无论关闭终端都在后台运行。
2.
-u
是为了禁止缓存,让结果可以直接进入日志文件flask_log.log3. 2>&1的意思
这个意思是把标准错误(2)重定向到标准输出中(1),而标准输出又导入文件output里面,所以结果是标准错误和标准输出都导入文件output里面了。 至于为什么需要将标准错误重定向到标准输出的原因,那就归结为标准错误没有缓冲区,而stdout有。这就会导致 >output 2>output 文件output被两次打开,而stdout和stderr将会竞争覆盖,这肯定不是我门想要的.
这就是为什么有人会写成: nohup ./command.sh >output 2>output出错的原因了