Hola... ¿Este comportamiento es falla del socket?

Iniciado por miltonprogramador, 27 Diciembre 2016, 17:05 PM

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

miltonprogramador

Hola chicos.. como bien me han ayudado en anteriores casos recientemente, hoy traigo una duda más... He realizado una aplicación cliente servidor (el cliente es una clase para pruebas del servidor, es decir, no es la aplicación final) mediante socket, pero toda va bien, excepto cuando pido al cliente conectarse con un bucle con multiples conexiones. esto lo hago para probar la funcionalidad del servidor... Al hacer esto comienza hacer el trabajo pero, si pido hacer 100 conexiones solo se conectan 80 y algo, es decir, la cantidad que se conecta no es constante pero esta en el orden de los 80  a 85 cuando intento conectar 100

El resultado a las fallidas es: "connect refused" en consola (porque alli pido mostrar la excepción)

Entonces no se si es la velocidad de mi procesador que no le es suficiente para sostener el servidor o es el problema de la cantidad alta simultánea de envios desde el cliente...

En fín, les dejo el código del cliente para que tengan un panorama más claro...
Código (java) [Seleccionar]


class Persona extends Thread {
    protected Socket sk;
    protected DataOutputStream dos;
    protected DataInputStream dis;
    private int id;
    public Persona(int id) {
        this.id = id;
    }
    @Override
    public void run() {
        //System.out.println("voy aqui: " + this.id);
        try {
                sk = new Socket("localhost", 10579);
                System.out.println(id + " envía saludox");
               // sk.close();
           
        } catch (Exception ex) {
            //Logger.getLogger(Persona.class.getName()).log(Level.SEVERE, null, ex);
            //System.out.println(id + "->Ha ocurrido algo inesperado... " + ex.getMessage());
            //ex.printStackTrace();
        }
    }
}
public class Cliente {
    public static void main(String[] args) {
       
        int hosts = 100;
        for (int i = 0; i < hosts; i++) {
           
            Thread clt = new Thread(new Persona(i));
            clt.start();
            try {
                clt.join();
            } catch (InterruptedException ex) {
                Logger.getLogger(Cliente.class.getName()).log(Level.SEVERE, null, ex);
            }
        }
    }
}



NOTA: En el join le he variado el tiempo, lo he colocado en 100, 400, 600, 800, 1000... ya mil me parece un tiempo laaargo, ahora el detalle es que ha mayor tiempo para la sincrnización es menor el margen de error.... MENOR pero el comportamiento sigue...

AUXILIOOO!
Aprendiendo de los mejores se llega a ser uno de ellos...

4dr14n31t0r

Pues yo empecé a mirar los sockets en java en mi clase el otro dia y obtuve ese error de "connect refused" porque ejecutaba el programa cliente antes que el servidor. Prueba a ejecutar antes el servidor y luego el cliente.