0

我正在使用多進程來完成2個任務。進程1是一個異步TCP服務器,它接收命令並且必須將這些命令傳遞給進程2(是真正的循環)。將隊列傳遞給handle_read函數async tcp server

我如何使用多處理,進程不共享全局變量,所以我必須使用隊列。但是,一個proccess 1是一個簡單的asynctcp服務器。我不知道如何將隊列對象傳遞給handle_read函數。

任何人有想法?非常感謝!

我試圖代碼:

#!usr/bin/env python3 
#import dos módulos necessarios 

import time 
import collections 
from datetime import datetime 
from datetime import timedelta 
from threading import Timer 
import os 
import sys 
from smbus import SMBus 
from struct import pack, unpack 
import threading 
from multiprocessing import Process, Queue 
import asyncore 
import socket 


bstatus = 0 
lastdata = {} 

#bytechecksum para confirmação 
chksum = 15 


#funções auxiliares 

def millis(): 
    dt = datetime.now()-start_time 
    ms = (dt.days*24*60*60 + dt.seconds)*1000+dt.microseconds/1000.0 
    return ms 

def getbit(data,index): 
    return(data & (1<<index)!=0) 

def parseData(data): 
    mydata = {} 

    if data[8] == 27: 
     mydata['Temp1'] = data[0] 
     mydata['Temp2'] = data[1] 
     mydata['Temp3'] = data[2] 
     mydata['Temp4'] = data[3] 
     mydata['HotFlow'] = data[4] 
     mydata['ColdFlow'] = data[5] 
     mydata['PumpSpeed'] = data[6] 
     mydata['PumpStatus'] = getbit(data[7],0) 
     mydata['HeaterStatus'] = getbit(data[7],1) 
     mydata['ArduinoMode'] = getbit(data[7],2) 
     mydata['TimeStamp'] = timezone.now().strftime('%Y-%m-%d %H:%M:%S.%f')[:-3] 

     #pegar o modo do arduino 
     arduino_mode = mydata['ArduinoMode']  
     parseStatus = True 
    else: 
     parseStatus = False 

    return parseStatus, mydata 


#classes para implmmentar o servidor assincrono 

class dataHandler(asyncore.dispatcher_with_send): 

    #this function doesn't working 
    def __init__(self,sock,queue): 
     self.queue = queue 
     self.sock = sock 

    def handle_read(self): 
     data = self.sock.recv(50) 

     '''interpretar os comandos: 
     operação: Ligar/Desligar Bomba, Ligar/Desligar Aquecedor, Alterar velocidade da bomba 
     Modo: trocar de modo automático para remoto 
     Armazenamento: ativar ou desativar o armazenamento de dados para o trend 
     ''' 

     if(data == b'7'): 
      operation_mode = 1 
      queue.put(data) 
      print(data) 

     elif(data == b'8'): 
      operation_mode = 0 
      queue.put(data) 
      print(data)   

     try: 
      bytescommand = pack('=cb',data,chksum) 
      bus.write_block_data(arduinoAddress,ord(data),list(bytescommand)) 
     except Exception as err: 
      print(str(err)) 
     finally: 
      pass 
      #print(data) 

class Server(asyncore.dispatcher): 

    def __init__(self,host,port,queue): 
     asyncore.dispatcher.__init__(self) 
     self.create_socket(socket.AF_INET,socket.SOCK_STREAM) 
     self.bind((host,port)) 
     self.listen(1) 
     self.queue = queue 

    def handle_accept(self): 
     pair = self.accept() 
     if pair is None: 
      return 
     else: 
      sock,addr = pair 
      handler = dataHandler(sock,self.queue) #doesn't working 


#classe para implementar a função principal 

def tcpserver(queue): 
    server = Server('localhost',8080,queue) 
    asyncore.loop() 

def mainloop(stime,ftime,queue): 
    prevmillis = stime 
    prevmillis2 = ftime 
    operation_mode = 1 
    while True: 
     try: 
      currentmillis2 = millis() 
      if(queue.empty): 
       pass 
      else: 
       print(queue.get()) 

      if(currentmillis2 - prevmillis2 > readinterval): 
       #do some stuff 


#programa principal 

if __name__=='__main__': 


    prevmillis= millis()  #contador para solicitação de dados para o arduino 
    prevmillis2 = prevmillis #contador para envio do banco 

    #create Queue 
    queue = Queue() 

    p1 = Process(target=tcpserver,args=(queue,)) 
    p1.start() 
    p2 = Process(target=mainloop,args=(prevmillis,prevmillis2,queue,)) 
    p2.start() 

    strstatus = 'Servidor rodando' 

    print(strstatus) 
+0

當程序得到您已標記爲不工作的語句時,程序會做什麼?是否引發異常?如果是這樣,請發佈回溯。 –

+0

不返回任何錯誤。但queue.get()從不執行,所以隊列總是空的。 – FelipeFonsecabh

回答

0

mainloop你不考的queue.empty的返回值,測試函數對象本身。總是評估True,所以它看起來像queue總是空的。更改爲函數調用:

def mainloop(stime,ftime,queue): 
    prevmillis = stime 
    prevmillis2 = ftime 
    operation_mode = 1 
    while True: 
     try: 
      currentmillis2 = millis() 
      if(queue.empty()): # Added() 
       pass 
      else: 
       print(queue.get()) 

      if(currentmillis2 - prevmillis2 > readinterval): 
       #do some stuff 
+0

謝謝!我會做一個測試 – FelipeFonsecabh