XIO:X服务器上的致命IO错误11(资源暂时不可用)在235个请求(235个已知处理)之后“0:0”,剩余0个事件

时间:2012-12-07 01:00:04

标签: python multiprocessing pygame

是的,其他人之前已经问过这个问题,但不是在相同的背景下或我的满意。所以,这里是::

我正在使用python编写一个应用程序,该程序使用pygame(ergo opengl)来显示图形。图形是在程序本身中生成的(因此没有任何目录问题)。

应用程序还需要从用户平行访问输入。为了实现这一点,我使用带管道的多处理块,并使用pygame事件循环读取输入键。下面的代码循环运行。第一次循环迭代工作正常,但在第二次迭代时,我抛出了XIO错误。

   parent, child = Pipe(duplex=True)
   # this function draws the canvas
   switches, retOrient = self.drawCanvas(cond, count, dispSize, moves)
   # this function gets the user input in another thread - stage 1
   p = Process(target=userInput, args=(self.button, child) )
   p.start()
   b_press = parent.recv()
   parent.close()

def userInput(button, child):
    button_pressed = button.blockAndWait()
    child.send( "%s"%(button_pressed.keyname) )
    child.close()

我对这个错误的发生方式感到有些困惑,XIO内部导致它的原因是什么。其他答案都没有解释这个错误的根本原因。考虑到它作为单个流程应用程序工作正常,多处理模块正在关闭一些IO通道(输入注册对象,显示对象或事件循环)或打开一些不必要的通道。如何解读导致此XIO错误的确切原因?

1 个答案:

答案 0 :(得分:8)

不一定是真正的答案,但我不会使用multiprocessing并行访问套接字,例如与X服务器的连接。这看起来不错。改为使用常规线程。

请注意multiprocessing是基于(有时)分叉的黑客攻击,所以当父母和孩子都试图访问它时,分叉套接字究竟会发生什么......是随机混合垃圾。

编辑:原因是两个分叉套接字仍然是套接字的“同一端”,X服务器保持在“另一端”。当X服务器想要发送消息时,它会在套接字上写入100个字节。但是如果你运气不好,分叉进程1读取前50个字节,分叉进程2读取剩余的50个字节。每个进程都意外地只获得了消息的随机部分。他们每个人都会抱怨X服务器发送废话。