子进程未正确调用我的命令

3 投票
1 回答
1091 浏览
提问于 2025-04-16 22:04

概述:

我有一个应用程序,有时候需要用到celery。如果只是简单的任务,比如计数,通常没问题。

不过,我有一个任务需要把现有的文件转换成另一个文件,使用的是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环境中调用这个命令,一切都正常。

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

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 个回答

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 进行软件渲染。

撰写回答