子进程没有调用我的命令(或者做错了)

时间:2011-07-22 12:26:22

标签: python django celery wine xvfb

概述:

我有一个应用程序,有时必须用芹菜做一些东西 - 如果它是一个简单的任务,如计数东西 - 一切都好。

我有一项任务必须使用MS Windows程序将现有文件转换为另一个文件。所以 - 我安装了WINE,然后安装了应用程序,并在我的tasks.py中添加了以下任务:

def convert_file( fil, to_format = 'pdf', save_to = '/tmp', callback = None ):
    devnull = open( '/dev/null', 'w' )
    commands = "xvfb-run -a wine '[ABSOLUTE_PATH_TO_WINDOWS_APP]' /r /f 104 %s" % fil
    p = subprocess.Popen( commands, shell=True, cwd='/home/test', env=os.environ, stdout = devnull, stderr = subprocess.STDOUT )
    p.wait()
    devnull.close()
    if callback:
        subtask( callback ).delay( )
    else:
        return outfile

问题:

该命令未被调用或被调用但没有发生任何事情(文件系统中没有任何新文件) - 但如果我将从bash或交互式python shell调用此命令,一切正常。

修改 当我从命令行调用命令时,我得到了这个:

test@ubuntu:~$ xvfb-run -a /home/test/.wine/....exe /r /f 104 /home/test/fs/...
err:winediag:X11DRV_WineGL_InitOpenglInfo The Mesa OpenGL driver is using software rendering, most likely your OpenGL drivers haven't been installed correctly
test@ubuntu:~$ XIO:  fatal IO error 11 (Zasoby chwilowo niedostępne) on X server ":99"
      after 1262 requests (1226 known processed) with 0 events remaining.
[Here i must press enter]
test@ubuntu:~$ 

1 个答案:

答案 0 :(得分:3)

使用

p = subprocess.Popen( commands, shell=True, cwd='/home/test', env=os.environ, stdout = subprocess.PIPE, stderr = subprocess.PIPE)

为您的Popen命令,然后

print p.communicate()
p.wait()
print p.communicate()

要查看它打印到stdoutstderr的内容,并弄清楚你做错了什么。

编辑:Xvfb是假帧缓冲;它没有硬件加速。尝试更改wine设置,不要求硬件加速/不使用OpenGL /使用winecfg进行软件渲染。