celery部署到服务器上

当我们写了一个celery的定时任务之后,我们需要将其放到我们服务器上并让其在后台执行。

我本来是直接部署到服务器上,然后执行了两句命令,但是没想到确失败了。经过一番资料的查找,我发现需要用到两个命令

1
2
3
4
5
6
7
8
9
10
&      -- 这个符号可以让你的程序在后台运行
nohup -- 这个命令可以让你的程序在你退出ssh链接之后不被杀死
eg:
nohup ./start-dishi.sh >output 2>&1 &

解释:
1. &符号的含义
带&的命令行,即使terminal(终端)关闭,或者电脑死机程序依然运行(前提是你把程序递交到服务器上);
2. 2>&1的意思
  这个意思是把标准错误(2)重定向到标准输出中(1),而标准输出又导入文件output里面,所以结果是标准错误和标准输出都导入文件output里面了。 至于为什么需要将标准错误重定向到标准输出的原因,那就归结为标准错误没有缓冲区,而stdout有。这就会导致 >output 2>output 文件output被两次打开,而stdout和stderr将会竞争覆盖,这肯定不是我门想要的.