2011-08-18 15 views
12

¿Cuál es la mejor forma de establecer comunicación entre dos procesos en python? Después de algunas google, traté de hacerlo:Comunicación de proceso en Python

parent_pipe, child_pipe = Pipe() 
p = Process(target = instance_tuple.instance.run(), \ 
    args = (parent_pipe, child_pipe,)) 
p.start() 

El envío de datos al proceso hijo:

command = Command(command_name, args) 
parent_pipe.send(command) 

Proceso función objetivo:

while True: 
    if (self.parent_pipe.poll()): 
     command = parent_pipe.recv() 
     if (command.name == 'init_model'): 
      self.init_model() 
     elif (command.name == 'get_tree'): 
      tree = self.get_fidesys_tree(*command.args) 
      result = CommandResult(command.name, tree) 
      self.child_pipe.send(result) 
     elif(command.name == 'set_variable'): 
      name = command.args[0] 
      value = command.args[1] 
      self.config[name] = value 

Pero no parece funcionar (el proceso hijo no recibe nada a través del parent_pipe). ¿Cómo puedo arreglarlo?

Gracias de antemano.

+0

Compruebe parent_pipe. ¿Alguna vez se hace una instancia? – krs1

+0

@ krs1 Sí, tanto en el proceso hijo como en el padre se crean instancias de las tuberías. –

Respuesta

5

Puede verla aquí: http://docs.python.org/library/multiprocessing.html#exchanging-objects-between-processes La solución está cerca de la suya, pero parece más fácil.

+0

El problema es que esta solución no funciona para mí por algún motivo. No puedo leer nada de la tubería aunque se envían datos. –

+0

Supongo que el problema es con la creación de instancias del proceso. El parámetro 'target' se usa para vincular una función a un extremo de la tubería. – Tom97531

0

Si entiendo la documentación, en el proceso secundario debe leer de la parte secundaria de la tubería.

# Process Target function 

while True: 
     # poll(None) because you don't want to go through the loop fast between commands 
     if (self.child_pipe.poll(None)):  
      command = child_pipe.recv() 
      if (command.name == 'init_model'): 
       self.init_model() 
      elif (command.name == 'get_tree'): 
       tree = self.get_fidesys_tree(*command.args) 
       result = CommandResult(command.name, tree) 
       self.child_pipe.send(result) 
      elif(command.name == 'set_variable'): 
       name = command.args[0] 
       value = command.args[1] 
       self.config[name] = value 
Cuestiones relacionadas