Socket中的backlog参数

    backlog参数为socket套接字监听端口时,内核为该套接字分配的一个队列大小,在服务端还没有来得及处理请求时暂时缓存请求所用的队列。如果队列已经被客户端socket占满了,还有新的连接过来,那么ServerSocket会拒绝新的连接。backlog提供了容量限制功能,避免太多的客户端socket占用太多服务器资源。
    注意如果连接处于休眠状态即没有数据传输是不属于服务处理中的连接,所以不会计算在内。

1、服务端仅接受连接请求不处理请求

// 1. 创建服务端socket套接字,此处可以指定端口,backlog参数,但是我们放在后面再指定
ServerSocket serverSocket = new ServerSocket();
// 2. 创建服务地址并指定端口号
SocketAddress socketAddress = new InetSocketAddress(InetAddress.getLocalHost(), 8888);
// 3. 绑定服务地址及端口号,并设置backlog
serverSocket.bind(socketAddress, 3);

请求连接到第四个时抛出异常。 

2、服务端接受并处理请求

public static void startServer() throws IOException {
// 1. 创建服务端socket套接字,此处可以指定端口,backlog参数,但是我们放在后面再指定
final ServerSocket serverSocket = new ServerSocket();
// 2. 创建服务地址并指定端口号
SocketAddress socketAddress = new InetSocketAddress(InetAddress.getLocalHost(), 8888);
// 3. 绑定服务地址及端口号,

你可能感兴趣的:(服务器,网络,运维)