当前位置:首页 > 文章列表 > 文章 > java教程 > JavaServerSocket从零开始教学,手把手教你搭建服务端Socket

JavaServerSocket从零开始教学,手把手教你搭建服务端Socket

2025-06-21 16:11:22 0浏览 收藏

想要轻松搞定服务端 Socket?本文为你提供一份 Java ServerSocket 手把手教学。ServerSocket 作为 Java 中监听客户端连接的核心类,掌握其使用至关重要。文章详细讲解了 ServerSocket 的核心使用步骤:创建并绑定端口、监听并接受连接、通过 Socket 流进行通信以及资源关闭。同时,针对高并发场景,提供了线程池和 NIO 两种性能提升方案。此外,还深入剖析了 `bind()` 方法、`backlog` 参数以及 `setSoTimeout()` 方法的具体应用,结合实际代码示例,让你彻底掌握 ServerSocket 的使用技巧,轻松构建稳定高效的 Java 服务端应用。

ServerSocket 是 Java 中用于监听客户端连接的核心类,其核心使用步骤包括:1. 创建 ServerSocket 并绑定端口;2. 调用 accept() 方法监听并接受连接;3. 通过 Socket 的输入输出流进行通信;4. 关闭资源。为应对高并发,可采用线程池或 NIO 技术提升性能;bind() 方法用于指定绑定的 IP 和端口;backlog 参数控制连接请求队列长度;setSoTimeout() 方法可设置 accept() 的超时时间。

Java中ServerSocket的用法 详解服务端Socket

服务端Socket,说白了,就是Java里 ServerSocket 这玩意儿。它负责监听客户端的连接请求,然后像个老鸨一样,把连接“分配”给其他的 Socket 去处理。简单来说,ServerSocket 负责接客,真正干活的是接到的 Socket

Java中ServerSocket的用法 详解服务端Socket

解决方案

Java中ServerSocket的用法 详解服务端Socket

想用好 ServerSocket,得先理解它的几个关键步骤:

  1. 创建 ServerSocket 这就像开店选址,你得指定一个端口号,让客户端能找到你。比如 ServerSocket serverSocket = new ServerSocket(8080); 这就在8080端口开了个店。
  2. 监听连接: serverSocket.accept() 这步很重要,它会阻塞程序,直到有客户端来连接。就像店员在门口等着客人上门。accept() 方法会返回一个新的 Socket 对象,这个 Socket 就代表了和客户端的连接。
  3. 处理连接: 拿到 Socket 对象后,就可以通过它的输入输出流和客户端通信了。这部分逻辑可以放在一个新的线程里处理,避免阻塞主线程。
  4. 关闭连接: 通信完毕,记得关闭 SocketServerSocket,释放资源。不然你的服务器迟早会被耗死。

一个简单的例子:

Java中ServerSocket的用法 详解服务端Socket
import java.net.*;
import java.io.*;

public class SimpleServer {
    public static void main(String[] args) throws IOException {
        ServerSocket serverSocket = null;
        try {
            serverSocket = new ServerSocket(8080);
            System.out.println("Server started on port 8080");

            while (true) {
                Socket clientSocket = serverSocket.accept();
                System.out.println("Client connected: " + clientSocket.getInetAddress().getHostAddress());

                // 处理客户端连接,可以放到单独的线程中
                new Thread(() -> {
                    try (
                        PrintWriter out = new PrintWriter(clientSocket.getOutputStream(), true);
                        BufferedReader in = new BufferedReader(new InputStreamReader(clientSocket.getInputStream()));
                    ) {
                        String inputLine;
                        while ((inputLine = in.readLine()) != null) {
                            System.out.println("Received: " + inputLine);
                            out.println("Server received: " + inputLine); // Echo back to client
                        }
                        System.out.println("Client disconnected: " + clientSocket.getInetAddress().getHostAddress());
                    } catch (IOException e) {
                        e.printStackTrace();
                    } finally {
                        try {
                            clientSocket.close();
                        } catch (IOException e) {
                            e.printStackTrace();
                        }
                    }
                }).start();
            }
        } catch (IOException e) {
            System.err.println("Could not listen on port: 8080.");
            System.exit(1);
        } finally {
            if (serverSocket != null) {
                try {
                    serverSocket.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

这个例子里,服务器会一直监听 8080 端口,每当有客户端连接,就创建一个新的线程来处理。每个线程负责读取客户端发来的数据,然后把数据原样返回给客户端。

如何处理大量并发连接?

单线程的 ServerSocket 肯定扛不住高并发。一个比较常见的做法是使用线程池。每当 ServerSocket 接受到一个新的连接,就从线程池里取出一个线程来处理。这样可以避免频繁创建和销毁线程的开销。

另外,还可以考虑使用非阻塞 I/O(NIO)。NIO 允许一个线程同时管理多个连接,大大提高了服务器的并发能力。像 Netty 这样的框架,就是基于 NIO 实现的。

ServerSocketbind() 方法有什么用?

bind() 方法用于将 ServerSocket 绑定到一个特定的地址和端口。如果你不显式调用 bind(),那么在创建 ServerSocket 的时候,系统会自动选择一个可用的端口。

有时候,你可能需要将 ServerSocket 绑定到一个特定的 IP 地址。比如,你的服务器有多个网卡,你希望 ServerSocket 只监听某个网卡上的连接。这时候,就可以使用 bind() 方法。

ServerSocket serverSocket = new ServerSocket();
SocketAddress socketAddress = new InetSocketAddress("192.168.1.100", 8080);
serverSocket.bind(socketAddress);

这段代码会将 ServerSocket 绑定到 IP 地址为 192.168.1.100 的网卡的 8080 端口。

ServerSocketbacklog 参数是什么意思?

backlog 参数指定了服务器可以接受的最大连接请求队列的长度。当服务器忙于处理其他连接时,新的连接请求会被放入这个队列中等待。如果队列满了,新的连接请求会被拒绝。

backlog 参数的值通常由操作系统决定,不同的操作系统有不同的默认值。你可以通过 ServerSocket 的构造函数来指定 backlog 的值。

ServerSocket serverSocket = new ServerSocket(8080, 100); // backlog = 100

但是,即使你指定了 backlog 的值,操作系统也可能会忽略你的设置,使用自己的默认值。

如何设置 ServerSocket 的超时时间?

有时候,你可能希望 ServerSocket 在一段时间内没有收到任何连接请求就自动关闭。这时候,可以设置 ServerSocket 的超时时间。

Java 并没有直接提供设置 ServerSocket 超时时间的方法。但是,你可以通过设置 Socket 的超时时间来实现类似的效果。

ServerSocket serverSocket = new ServerSocket(8080);
serverSocket.setSoTimeout(5000); // 设置超时时间为 5 秒

try {
    Socket clientSocket = serverSocket.accept();
    // ...
} catch (SocketTimeoutException e) {
    System.out.println("Timeout occurred");
}

这段代码会设置 ServerSocket 的超时时间为 5 秒。如果在 5 秒内没有收到任何连接请求,accept() 方法会抛出一个 SocketTimeoutException 异常。

需要注意的是,setSoTimeout() 方法设置的是 Socket 的超时时间,而不是 ServerSocket 的超时时间。但是,由于 accept() 方法返回的是一个 Socket 对象,所以设置 Socket 的超时时间可以间接实现 ServerSocket 的超时效果。

好了,本文到此结束,带大家了解了《JavaServerSocket从零开始教学,手把手教你搭建服务端Socket》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!

Go语言版本升级遇到不兼容?超详细迁移教程来了!Go语言版本升级遇到不兼容?超详细迁移教程来了!
上一篇
Go语言版本升级遇到不兼容?超详细迁移教程来了!
Python中的星号
下一篇
Python中的星号"*"到底有何神通?手把手教你搞定各种骚操作
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    511次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    498次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 千音漫语:智能声音创作助手,AI配音、音视频翻译一站搞定!
    千音漫语
    千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
    125次使用
  • MiniWork:智能高效AI工具平台,一站式工作学习效率解决方案
    MiniWork
    MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
    122次使用
  • NoCode (nocode.cn):零代码构建应用、网站、管理系统,降低开发门槛
    NoCode
    NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
    136次使用
  • 达医智影:阿里巴巴达摩院医疗AI影像早筛平台,CT一扫多筛癌症急慢病
    达医智影
    达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
    131次使用
  • 智慧芽Eureka:更懂技术创新的AI Agent平台,助力研发效率飞跃
    智慧芽Eureka
    智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
    132次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码