Mr·Li博客

服务后台运行一个任务并记录日志

lixiaobin·2020-11-26 10:03·466 次阅读

服务后台运行一个任务并记录日志

需求:在服务器上后台运行一个任务

实现:

1
python3.7.6 /data/py_shell/dp_report/distributionOrder.py > /data/py_shell/dp_report/logs/distributionOrder_day.log  2>&1  & ← 后台运行      ↑                                ↑                                              ↑                                 ↑ python版本                       执行任务的位置                                    生成日志位置                    将标准错误重定向到标准输出

 

这个有个缺点,就是服务器退出后,任务也结束了,要是后台运行一个接口,让它不停止工作所以用到 nohup命令

1
nohup python3.7.6 /data/py_shell/dp_report/interface_car.py  >/data/py_shell/dp_report/logs/myout.log 2>&1 &

以下是对nohup的介绍:

用途:不挂断地运行命令。
语法:nohup Command [ Arg ... ] [ & ]
描述:nohup 命令运行由 Command 参数和任何相关的 Arg 参数指定的命令,忽略所有挂断(SIGHUP)信号。在注销后使用 nohup 命令运行后台中的程序。要运行后台中的 nohup 命令,添加 & ( 表示“and”的符号)到命令的尾部。

操作系统中有三个常用的流:
  0:标准输入流 stdin
  1:标准输出流 stdout
  2:标准错误流 stderr
  一般当我们用 > console.txt,实际是 1>console.txt的省略用法;< console.txt ,实际是 0 < console.txt的省略用法。
 
下面步入正题:
>nohup ./start-dishi.sh >output 2>&1 &
解释:
 1. 带&的命令行,即使terminal(终端)关闭,或者电脑死机程序依然运行(前提是你把程序递交到服务器上); 
 2. 2>&1的意思 
  这个意思是把标准错误(2)重定向到标准输出中(1),而标准输出又导入文件output里面,所以结果是标准错误和标准输出都导入文件output里面了。 至于为什么需要将标准错误重定向到标准输出的原因,那就归结为标准错误没有缓冲区,而stdout有。这就会导致 >output 2>output 文件output被两次打开,而stdout和stderr将会竞争覆盖,这肯定不是我门想要的. 
  这就是为什么有人会写成: nohup ./command.sh >output 2>output出错的原因了
posted @   Mr·Li程序员  阅读(466)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
点击右上角即可分享
微信分享提示