概述:
我有一个应用程序,有时必须用芹菜做一些东西-如果这是简单的任务,例如算点东西-一切都很好.
我有一个任务,必须使用MS Windows程序将现有文件转换为另一个文件.所以-我安装了WINE,然后安装了应用程序,并将以下任务添加到我的task.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:~$
解决方法:
采用
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()
要查看打印到stdout和stderr的内容,并弄清楚您做错了什么.
编辑:Xvfb是伪造的帧缓冲区;它没有硬件加速.尝试更改wine设置,不需要硬件加速/不使用OpenGL /使用winecfg进行软件渲染.