游乐游手机版
首页/编程语言/文章详情

Java在Linux如何进行网络编程

时间:2026-05-02 11:46
在Linux上玩转Ja va网络编程:从TCP到UDP的实战指南 想在Linux环境下让Ja va应用“开口说话”,实现网络通信吗?这事儿其实没想象中那么复杂。核心就在于用好Ja va标准库里的ja va net包。下面,咱们就通过几个清晰明了的示例,一步步看看如何搭建起最基本的网络对话通道。 1

在Linux上玩转Ja va网络编程:从TCP到UDP的实战指南

Ja va在Linux如何进行网络编程

想在Linux环境下让Ja va应用“开口说话”,实现网络通信吗?这事儿其实没想象中那么复杂。核心就在于用好Ja va标准库里的ja va.net包。下面,咱们就通过几个清晰明了的示例,一步步看看如何搭建起最基本的网络对话通道。

1. 创建一个简单的TCP服务器

TCP协议好比打电话,需要先建立稳定的连接,再进行可靠的数据传输。这是最经典、最常用的网络编程模型。

服务器端代码

import ja va.io.*;
import ja va.net.*;

public class TCPServer {
    public static void main(String[] args) {
        int port = 12345; // 服务器监听的端口
        try (ServerSocket serverSocket = new ServerSocket(port)) {
            System.out.println("服务器已启动,正在监听端口 " + port);
            while (true) {
                Socket clientSocket = serverSocket.accept();
                System.out.println("客户端已连接: " + clientSocket.getInetAddress());
                // 处理客户端请求
                BufferedReader in = new BufferedReader(new InputStreamReader(clientSocket.getInputStream()));
                PrintWriter out = new PrintWriter(clientSocket.getOutputStream(), true);
                String inputLine;
                while ((inputLine = in.readLine()) != null) {
                    System.out.println("收到客户端消息: " + inputLine);
                    out.println("服务器已收到: " + inputLine);
                }
                clientSocket.close();
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

这段代码的核心是ServerSocket。它在指定端口上“安营扎寨”,通过accept()方法等待客户端的“敲门”。一旦连接建立,就通过Socket对象获取输入输出流,开始与客户端进行“你一言我一语”的对话。注意,这是一个简单的单线程模型,一个客户端处理完才会接待下一个。

客户端代码

import ja va.io.*;
import ja va.net.*;

public class TCPClient {
    public static void main(String[] args) {
        String hostname = "localhost"; // 服务器地址
        int port = 12345; // 服务器监听的端口
        try (Socket socket = new Socket(hostname, port)) {
            System.out.println("已连接到服务器 " + hostname + ":" + port);
            BufferedReader userInput = new BufferedReader(new InputStreamReader(System.in));
            PrintWriter out = new PrintWriter(socket.getOutputStream(), true);
            BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
            String userInputLine;
            while ((userInputLine = userInput.readLine()) != null) {
                out.println(userInputLine);
                String response = in.readLine();
                System.out.println("服务器回复: " + response);
            }
        } catch (UnknownHostException e) {
            System.err.println("未知主机: " + hostname);
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

客户端这边就主动多了。直接用Socket指定服务器地址和端口,发起连接。连接成功后,同样获取输入输出流,将用户在控制台输入的内容发送给服务器,并等待回音。这就完成了一次完整的TCP交互闭环。

2. 创建一个简单的UDP服务器

如果说TCP是打电话,那UDP就像是寄明信片。它无需建立连接,直接将数据包(DatagramPacket)扔向目标地址,速度快但不管对方是否收到。

服务器端代码

import ja va.io.*;
import ja va.net.*;

public class UDPServer {
    public static void main(String[] args) {
        int port = 12345; // 服务器监听的端口
        try (DatagramSocket socket = new DatagramSocket(port)) {
            System.out.println("UDP服务器已启动,正在监听端口 " + port);
            byte[] buffer = new byte[1024];
            DatagramPacket packet = new DatagramPacket(buffer, buffer.length);
            while (true) {
                socket.receive(packet); // 等待接收数据包
                String received = new String(packet.getData(), 0, packet.getLength());
                System.out.println("收到客户端消息: " + received);
                // 发送回复
                String response = "服务器已收到: " + received;
                DatagramPacket responsePacket = new DatagramPacket(response.getBytes(), response.length(), packet.getAddress(), packet.getPort());
                socket.send(responsePacket);
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

UDP服务器使用DatagramSocket在端口上监听。它准备一个空“包裹”(DatagramPacket),然后调用receive()方法等待“邮差”送来数据。收到后,从包裹里取出信息,并可以立刻根据发送者的地址和端口(都包含在packet里)打包一个回复包裹发送回去。

客户端代码

import ja va.io.*;
import ja va.net.*;

public class UDPClient {
    public static void main(String[] args) {
        String hostname = "localhost"; // 服务器地址
        int port = 12345; // 服务器监听的端口
        try (DatagramSocket socket = new DatagramSocket()) {
            InetAddress address = InetAddress.getByName(hostname);
            BufferedReader userInput = new BufferedReader(new InputStreamReader(System.in));
            String userInputLine;
            while ((userInputLine = userInput.readLine()) != null) {
                byte[] buffer = userInputLine.getBytes();
                DatagramPacket packet = new DatagramPacket(buffer, buffer.length, address, port);
                socket.send(packet); // 发送数据包
                byte[] responseBuffer = new byte[1024];
                DatagramPacket responsePacket = new DatagramPacket(responseBuffer, responseBuffer.length);
                socket.receive(responsePacket); // 等待接收回复
                String response = new String(responsePacket.getData(), 0, responsePacket.getLength());
                System.out.println("服务器回复: " + response);
            }
        } catch (UnknownHostException e) {
            System.err.println("未知主机: " + hostname);
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

UDP客户端同样使用DatagramSocket,但它不需要先连接。每次发送数据时,都需要明确指定目标地址和端口,封装成一个DatagramPacket,然后调用send()方法“寄出”。发送后,它可以立即(或稍后)调用receive()来尝试接收服务器的回复包裹。

3. 编译和运行

代码写好了,怎么在Linux上让它跑起来?步骤非常直接。

编译服务器和客户端

ja vac TCPServer.ja va
ja vac TCPClient.ja va

打开终端,导航到你的Ja va文件目录,用ja vac命令分别编译服务器和客户端程序。UDP程序的编译命令完全一样,只是文件名不同。

运行服务器和客户端

ja va TCPServer
ja va TCPClient

编译成功后,先在一个终端窗口运行服务器程序(ja va TCPServer),它会开始监听。然后在另一个终端窗口运行客户端程序(ja va TCPClient),就可以开始通信了。UDP服务器和客户端的运行方式完全相同。

4. 注意事项

  • 防火墙:这是第一个要排查的“拦路虎”。确保你的Linux防火墙(如firewalldufw)允许程序所使用的端口(如示例中的12345)进行通信。
  • 性能与扩展:示例中的TCP服务器是单线程的,一次只能服务一个客户端。这在生产环境中是远远不够的。一个常见的优化方案是使用线程池ExecutorService)来处理accept()到的每一个客户端连接,从而能够并发服务多个客户端,大幅提升服务器的吞吐能力和响应速度。

好了,从建立可靠的TCP连接到发送轻快的UDP数据包,一套完整的流程就在这儿了。掌握了这些基础,你就已经拿到了在Linux世界用Ja va进行网络通信的钥匙。接下来,无论是构建复杂的微服务通信,还是实现自定义的应用层协议,都可以从这些基石上开始搭建。

来源:https://www.yisu.com/ask/99692047.html
上一篇Java代码在Linux如何高效编译 下一篇嫌弃PHP自带的测试工具难用?Composer一键安装PHPUnit搭建测试基石
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

补充同频道和同主题内容,方便继续浏览更多相关内容。

同类最新

继续查看同栏目最近更新的文章。

更多
深入解析 TransactionProxyFactoryBean 功能实现与实战案例
编程语言 · 2026-07-02

深入解析 TransactionProxyFactoryBean 功能实现与实战案例

本文通过一个订单处理系统的实际案例,探讨了Spring框架中TransactionProxyFactoryBean的功能实现。文章分析了其如何通过代理模式为普通JavaBean添加声明式事务管理能力,详细阐述了其配置方式、内部工作机制,包括如何创建AOP代理以及如何与PlatformTransactionManager协作。最后,通过对比现代基于注解的事务管

TransactionProxyFactoryBean 在 Java 编程中的应用与配置详解
编程语言 · 2026-07-02

TransactionProxyFactoryBean 在 Java 编程中的应用与配置详解

本文探讨了TransactionProxyFactoryBean在Spring框架中的应用,重点解析其作为声明式事务管理核心组件的工作原理。文章阐述了该工厂Bean如何通过AOP代理机制为目标对象自动添加事务边界,详细说明了其关键配置属性如事务管理器、事务属性及目标对象的设置方法,并分析了其内部代理创建流程。最后,讨论了其优势与在现代Spring应用中的演进

WebService实战案例详解与应用场景解析
编程语言 · 2026-07-02

WebService实战案例详解与应用场景解析

本文通过一个具体的订单查询案例,深入解析WebService的核心概念与实战应用。内容涵盖WebService的基本原理、使用Java和CXF框架构建服务端与客户端的完整步骤,以及XML数据绑定、服务发布与调用等关键技术细节。旨在为开发者提供清晰、实用的WebService开发指导,帮助理解其在实际项目中的集成与通信机制。

HttpClient与其他HTTP库性能功能对比分析
编程语言 · 2026-07-02

HttpClient与其他HTTP库性能功能对比分析

在Java开发中,处理HTTP请求有多种库可选,其中ApacheHttpClient以其成熟稳定著称。本文对比分析了HttpClient与其他主流HTTP库(如JDK原生HttpURLConnection、OkHttp、SpringRestTemplate及Retrofit)在功能特性、性能表现、易用性及适用场景上的差异,旨在帮助开发者根据项目需求,如对连接

MemSQL数据库实战应用案例深度解析
编程语言 · 2026-07-02

MemSQL数据库实战应用案例深度解析

本文探讨了MemSQL在实时分析场景中的实战应用。通过剖析一个典型的电商实时用户行为分析项目案例,阐述了MemSQL如何利用其混合事务 分析处理能力、内存优化与列式存储特性,高效处理高并发数据流与复杂查询。文章重点介绍了技术选型考量、架构设计、性能优化策略及实际效果,为面临类似实时数据处理挑战的项目提供参考。