stdout和stderr来自用芹菜包裹的面料任务

时间:2012-06-14 20:10:22

标签: python django celery fabric

我正在运行一个简单的任务,从django视图触发:

task = mock_deploy.delay()

mock_deploy定义为:

from celery.decorators import task as ctask
from project.fabscripts.task.mock import *

@ctask(name="mock_deploy")
def mock_deploy():
    print "hi form celery task b4 mockdeploy 1234"
    output = execute(mock_deploy2)
    return "out: %s" % (output)

结构任务本身定义为:

@task
def mock_deploy2():
    lrun("ls -l /")
    lrun("ifconfig eth0")
    # i need to get the full output from those commands and save them to db

现在......我试图替换stdout,覆盖结构执行功能:

def execute(task):
    output = StringIO()
    error = StringIO()
    sys.stdout = output
    sys.stderr = error
    task()
    sys.stdout = sys.__stdout__
    sys.stderr = sys.__stderr__
    return (output.getvalue(), error.getvalue())

我试图在结构任务中替换stdout。无论我做了什么,我得到的唯一输出是“面料想要做什么”的第一线

out: [localhost] local: ls -l / 

然后,ls命令的整个输出在芹菜日志中完全打印出来。除了丢失的一行out:[localhost] local:ls -l /`9我设法获得的输出)

[2012-06-14 21:33:56,587: DEBUG/MainProcess] TaskPool: Apply <function execute_and_trace at 0x36710c8> (args:('mock_deploy', '2a90d920-130a-4942-829b-87f4d5ebe80f', [], {}) kwargs:{'hostname': 's16079364', 'request': {'retries': 0, 'task': 'mock_deploy', 'utc': False, 'loglevel': 10, 'delivery_info': {'routing_key': u'celery', 'exchange': u'celery'}, 'args': [], 'expires': None, 'is_eager': False, 'eta': None, 'hostname': 's16079364', 'kwargs': {}, 'logfile': None, 'id': '2a90d920-130a-4942-829b-87f4d5ebe80f'}})
[2012-06-14 21:33:56,591: DEBUG/MainProcess] Task accepted: mock_deploy[2a90d920-130a-4942-829b-87f4d5ebe80f] pid:22214
hi form celery task b4 mockdeploy 1234
total 3231728
-rw-r--r--   1 root root 3305551148 2012-06-13 14:43 dumpling.sql
drwxr-xr-x   2 root root       4096 2012-05-09 17:42 bin
drwxr-xr-x   4 root root       4096 2012-02-14 15:21 boot
drwxr-xr-x   2 root root       4096 2012-03-09 14:10 build
drwxr-xr-x   2 root root       4096 2010-05-11 19:58 cdrom
-rw-------   1 root root    2174976 2012-05-23 11:23 core
drwxr-xr-x  15 root root       4080 2012-06-11 12:55 dev
drwxr-xr-x 135 root root      12288 2012-06-14 21:15 etc
drwxr-xr-x   6 root root         77 2012-05-21 14:41 home

...

一个可怕的可怕解决方法是结束一个结构运行命令,在每个命令上添加一个“&gt; /tmp/logfile.log”,然后当任务完成后,用scp检索文件......

我的问题很简单,当用芹菜触发时,如何获得结构任务的完整输出?

以下是诀窍:

@ctask(name="mock_deploy")
def mock_deploy():
    env.roledefs.update({'remote':  ['root@1.1.1.1',]})
    output = StringIO()
    sys.stdout = output
    execute(mock_deploy2)
    sys.stdout = sys.__stdout__
    return output.getvalue()

0 个答案:

没有答案