2011-08-18 19 views
12

Qual è il modo migliore per stabilire la comunicazione tra due processi in python? Dopo un po 'googling, ho cercato di farlo:Comunicazione di processo in Python

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

invio dei dati al processo figlio:

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

Processo funzione target:

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 

Ma non sembra funzionare (processo figlio non riceve nulla tramite parent_pipe). Come posso ripararlo?

Grazie in anticipo.

+0

Controllare parent_pipe. Viene mai istanziato? – krs1

+0

@ krs1 Sì, entrambe le pipe dei processi figlio e padre vengono istanziate. –

risposta

5

Potete dare un'occhiata qui: http://docs.python.org/library/multiprocessing.html#exchanging-objects-between-processes La soluzione è vicina alla tua ma sembra più facile.

+0

Il fatto è che questa soluzione non funziona per me per qualche motivo. Non riesco a leggere nulla dalla pipe anche se i dati vengono inviati. –

+0

Immagino che il problema sia con la tua istanziazione del processo. Il parametro 'target' viene utilizzato per collegare una funzione a una estremità della pipe. – Tom97531

0

Se ho capito la documentazione, nel processo figlio dovresti leggere dalla parte secondaria del tubo.

# 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