Foro de elhacker.net

Programación => Scripting => Mensaje iniciado por: lovita en 13 Marzo 2008, 09:06 am



Título: hilos en python que tardan mucho
Publicado por: lovita en 13 Marzo 2008, 09:06 am
Hola a todos,

Tengo una aplicación en la que envío el mismo mensaje a un conjunto de PC's.

Uso un hilo por cada socket a enviar:

> import thread
> ....
> ...
> ...
>
> for ip in ips: #ips es una lista con las ips destino
> thread.start_new(envia_socket,(ip,puerto,mensaje))
>

La función envia_socket sólo se dedica a enviar el mensaje al destino:

> def envia_socket(servidor,puerto,msg):
>
> s=socket(AF_INET,SOCK_STREAM) #creamos socket tipo TCP/IP
> #s.settimeout(20)
> try:
> s.connect((servidor,puerto)) #nos conectamos al servidor
> s.send(msg)
> s.close() # cerramos conexion
> envio_ok.append(servidor)
> except timeout:
> error1.append(servidor)
> except error: # si error capturamos excep
> error2.append(servidor)
>

El problema es que si envío un mensaje a un sólo equipo y el pc está apagado el socket intenta conectar durante unos 20 seg. En cambio si se lo mando a unos 30 equipos y estos está apagados la ejecución se demora hasta pasar el minuto. Si uso threading me ocurre lo mismo. Y si establezco un settimeout he de poner un tiempo elevado para que recorra todos los equipos.

No sé si estos tiempos son normales, pero si son procesos en pararelos ... ¿no debería tardarme aproximadamente lo mismo en enviar a un equipo que a varios? Creo que algo hago mal, a ver si pueden ayudarme. Gracias !


Título: Re: hilos en python que tardan mucho
Publicado por: Ragnarok en 14 Marzo 2008, 00:19 am
Bienvenido, lee las normas y usa las etiquetas de código, porque si no ya ves que sale bastante mal. Prueba a hacer esto:

Código
  1. import thread
  2. ....
  3. ...
  4. ...
  5.  
  6. for ip in ips: #ips es una lista con las ips destino
  7.  thread.start_new(envia_socket,(ip,puerto,mensaje))
Código
  1. def envia_socket(servidor,puerto,msg):
  2.  print 'inicio', servidor
  3.  s=socket(AF_INET,SOCK_STREAM) #creamos socket tipo TCP/IP
  4.    #s.settimeout(20)
  5.    try:
  6.      s.connect((servidor,puerto)) #nos conectamos al servidor
  7.      s.send(msg)
  8.      s.close() # cerramos conexion
  9.      envio_ok.append(servidor)
  10.    except timeout:
  11.      error1.append(servidor)
  12.    except error: # si error capturamos excep
  13.      error2.append(servidor)
  14.  print 'fin', servidor

Sólo para ver qué pasa.


Título: Re: hilos en python que tardan mucho
Publicado por: lovita en 14 Marzo 2008, 09:46 am
Gracias, y ... siento lo del código, no se volverá a repetir.

Al ejecutar ahora el código, primero se imprimen rápida y ordenadamente todos los 'inicio' servidor, posteriormente y desordenadamente los 'fin' servidor, y en esto es lo que se lleva más tiempo, además, los 'fin' servidor se imprimen como en grupos de tres o cuatros seguidos se lleva un tiempo procesando y vuelve a imprimirse otro bloque, así hasta recorrer todos los servidores.  :o   


Título: Re: hilos en python que tardan mucho
Publicado por: Ragnarok en 14 Marzo 2008, 23:44 pm
Entonces el problema no son los hilos, que se crean todos a la vez, sino el límite de conexiones, que dices que es 3 o 4. O eso es lo que deduzco de la traza, python lo he usado lo justo.