当需要0x时,Celeryd脚本打印输出2x



这是我运行celeryd:的小脚本

#!/bin/bash -x
LOG=/home/var/log/ingest.log
sudo -u apache bash -c "nohup `pwd`/bin/django celeryd --purge --beat --loglevel=INFO >> $LOG &"

我以普通用户的身份运行脚本,并在请求时输入root密码。

我真的希望看到没有任何输出-所有的东西都发送到日志中。相反,我看到一切都翻了一番:

[2012-03-19 19:54:38,987: INFO/PoolWorker-2] Received feed. 0 new entries out of 3 to process.
[2012-03-19 19:54:38,987: INFO/PoolWorker-2] Received feed. 0 new entries out of 3 to process.
[2012-03-19 19:54:38,988: INFO/MainProcess] Task atom_ingest.walk_feed[64d8e6c7-2ab4-4082-9d67-a8ecca9a4f7a] succeeded in 1.85489702225s: None
[2012-03-19 19:54:38,988: INFO/MainProcess] Task atom_ingest.walk_feed[64d8e6c7-2ab4-4082-9d67-a8ecca9a4f7a] succeeded in 1.85489702225s: None
[2012-03-19 19:55:32,083: INFO/Beat] Scheduler: Sending due task atom_ingest.walk_feeds
[2012-03-19 19:55:32,083: INFO/Beat] Scheduler: Sending due task atom_ingest.walk_feeds
[2012-03-19 19:55:32,285: INFO/MainProcess] Got task from broker: atom_ingest.walk_feeds[e65ddc54-23a5-46a0-86df-92479f79655b]
[2012-03-19 19:55:32,285: INFO/MainProcess] Got task from broker: atom_ingest.walk_feeds[e65ddc54-23a5-46a0-86df-92479f79655b]

这些输出都来自"后台",这意味着当我做其他事情时,它会溢出我的终端。

我真的不确定我的错误是否在于我对bash、celeryd、nohup的理解。。。?

您可以告诉celeryd使用选项-f登录到一个文件。

你仍然会得到一些输出。celeryd似乎忽略了任何使用输出2>&1 > /your/file/重定向的尝试。

p.S:我建议找一些类似Supervisor的东西来管理你的流程。

相关内容

  • 没有找到相关文章

最新更新