Administrar múltiples sockets

Iniciado por .:UND3R:., 11 Febrero 2014, 13:27 PM

0 Miembros y 1 Visitante están viendo este tema.

.:UND3R:.

Hola a todos tengo una duda, como podría administrar múltiples clientes, me baso en la idea de Poison Ivy, Bifrost, entre otros rat.

Mi idea es crear un thread por cada conexión recibida y asignar un especie de identificador único y ese mismo identificador agregarlo a una tabla. Ahora cuando quiera realizar una acción en un servidor específico ¿cómo lo haría?

No existe alguna guía en donde se estructure la administración de conexiones?, saludos y gracias

Solicitudes de crack, keygen, serial solo a través de mensajes privados (PM)

Arkangel_0x7C5

#1
Un hilo por cada conexión no es escalable.
Luego para administrarlo solo necesitas tener una lista(Lista enlazada) de conexiones y en la interface grfica. pues con un listBox que cambie entre conexiones para que todo lo que hagas se realice sobre la conexión que esta actualmente seleccionada. Si quieres usar varias conexiones usa los i/o completion port que permiten a unos cuantos hilos manejar muchisimas conexiones de manera asíncrona

un saludo Ark

PD: ejemplo de iocp aqui

.:UND3R:.

Cita de: Arkangel_0x7C5 en 12 Febrero 2014, 11:54 AM
Un hilo por cada conexión no es escalable.
Luego para administrarlo solo necesitas tener una lista(Lista enlazada) de conexiones y en la interface grfica. pues con un listBox que cambie entre conexiones para que todo lo que hagas se realice sobre la conexión que esta actualmente seleccionada. Si quieres usar varias conexiones usa los i/o completion port que permiten a unos cuantos hilos manejar muchisimas conexiones de manera asíncrona

un saludo Ark

PD: ejemplo de iocp aqui

Me ha quedado todo claro excepto el "No es escalable", a que te refieres con eso?, saludos (me diste una gran solución muchas gracias :) )

Solicitudes de crack, keygen, serial solo a través de mensajes privados (PM)

Arkangel_0x7C5

pues con lo de escalable me refiero a quecon forme aumentas el numero de conexiones e hilos vas gastando mas y mas recursos
Y llega un momento en que el SO esta mas tiempo cambiando de hilo que ejecutandolos

un saludo

Vaagish

Citarpues con lo de escalable me refiero a quecon forme aumentas el numero de conexiones e hilos vas gastando mas y mas recursos
Y llega un momento en que el SO esta mas tiempo cambiando de hilo que ejecutandolos

Pero supone un problema grave?? Es decir.. da como para saturar el procesador? Siempre suponiendo que no van a haber 10.000 computadoras conectadas.. Yo seria de la idea de los hilos, o al menos hacer una prueba..

Saludos!

Vaagish

Esta como medio raro ese ejemplo:

Citar>device.ioCompletion((IODevice*)io,buff,
                                                                   BytesTransfered,opCode,
                                                                   errorCode);
                break;
            case OP_CLOSE:
                if(io->device.ioCompletion)io->device.ioCompletion((IODevice*)io,buff,
                                                                   BytesTransfered,opCode,
                                                                   errorCode);
                io->device.closeHandle((IODevice*)io);
                free(io);
            default:
                ;
        }

.:UND3R:.

Si pongo dos variables en el main, una identifica a que cliente quiero referirme y otra que operación pretendo realizar, cada hilo verifica si el identificador se refiere a el y en el caso que sea así realiza la opción, ¿Qué les parece?

Solicitudes de crack, keygen, serial solo a través de mensajes privados (PM)

Vaagish

Seria algo así como utilizar los dos métodos? Debería funcionar, quizás quede un poco mas pesado, y no estoy seguro que valga la pena,, pero puede quedar bien organizado.. creo que vas a tener que optar por la que mas te parezca, o... dedicarle un poco mas de tiempo y probar todas.. la que resulte mas fácil/funcional de implementar es la que utilizas..

Suerte! Saludos!

PD: Si queres tengo algo medio armado en sockets Asyn en C++

Arkangel_0x7C5

Cita de: Vaagish en 12 Febrero 2014, 23:33 PM
Esta como medio raro ese ejemplo:

Ya esta corregido, la actualizacion de ese foro parece que estropeo un poco la vusualizacion

.:UND3R:.
Si guardas una lista de los clientes, en esa estructura podrias poner si quisieras una cola de operaciones a realizar

Pero bueno, con lo que te enseñe de IOCP, da igual el hilo que realice las operaciones de lectura escritura
Y si te fijas, la estructura overlapped puedes modificarla a gusto paar poner que operacion hay que realizar y poner un puntero que apunte a datos o a un contexto como la informacion de el cliente

un saludo
PD: lo de saturar el procesador no se cuando empezaria a ocurrir, porque depende de la maquina y del SO

moikano→@

Si tu idea es hacerlo con linux hay un programa que gestiona las conexiones, su uso es parecido a netcat pero crea sockets por cada conexión que recibe.
El programa es tcpserver, aún no lo he probado pero me lo recomendo un compañero del cual me fio al 100%, además el creador del programa es el mismo que el de supervisor entre otros, así que tiene que se rde calidad.

El enlace http://cr.yp.to/ucspi-tcp/tcpserver.html.

Ten en cuenta que el verdadero limite de conexiones que tendrás serán el número de puertos, pero no creo que tengas siempre todas las máquinas encendidas y conectadas.

Espero haber sido de ayuda. Saludos.