Java ServerSocket connection limit?

后端 未结 4 1984
北恋
北恋 2020-12-10 04:57

I was running a few tests with sockets, and I encountered some strange behavior: A ServerSocket will refuse connections after the 50th client Socket connects to it, even if

相关标签:
4条回答
  • 2020-12-10 05:25

    Two things you may look at

    1. Server is not accepting connection.
    2. Server is unable to cater too many connection at same time instance. It might caused by increased backlog (beyond 50). Try giving some time gap in milli seconds before connecting to server again. Like ramp up connections. I solved it by giving some time gap when i ran test load.
    0 讨论(0)
  • 2020-12-10 05:29

    It's all in the JavaDoc:

    The maximum queue length for incoming connection indications (a request to connect) is set to 50. If a connection indication arrives when the queue is full, the connection is refused.

    Apparently your ServerSocket never accepts any connections, just listens. You must either call accept() and start handling the connection or increase the backlog queue size:

    new ServerSocket(port, 100)
    
    0 讨论(0)
  • 2020-12-10 05:31

    50 is the default value for backlog

    http://docs.oracle.com/javase/1.4.2/docs/api/java/net/ServerSocket.html#ServerSocket%28int%29

    The maximum queue length for incoming connection indications (a request to connect) is set to 50. If a connection indication arrives when the queue is full, the connection is refused.

    0 讨论(0)
  • 2020-12-10 05:31

    Here's an example that works, in accordance with @TomaszNurkiewicz's answer:

    import java.net.*;
    import java.util.concurrent.atomic.AtomicBoolean;
    
    public class SockTest{
    public static void main(String[] args) {
        final AtomicBoolean shouldRun = new AtomicBoolean(true);
        try  {
            final ServerSocket server = new ServerSocket(2123);
            Thread serverThread = new Thread(){
               public void run() {
                  try {
                     while(shouldRun.get()) {
                     Socket s = server.accept();
                     s.close();
                 Thread.sleep(1);
                    }
                  } catch(Exception ex) {
                    ex.printStackTrace();
                  }
               }
            };
            serverThread.start();
            Socket[] clients = new Socket[150];
            for (int i = 0; i < clients.length; i++) {
                clients[i] = new Socket("localhost", 2123);
                System.out.printf("Client %2d: " + clients[i] + "%n", i);
                clients[i].close();
            }
            shouldRun.set(false);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
           shouldRun.set(false);
        }
    
      }
    }
    
    0 讨论(0)
提交回复
热议问题