gpt4 book ai didi

java聊天服务器多个服务器套接字用于处理不同的功能

转载 作者:行者123 更新时间:2023-12-01 12:18:32 25 4
gpt4 key购买 nike

我正在学习java,有一个小问题。我目前正在制作一个工作正常的多线程聊天服务器。它看起来有点精简的 MSN 信使,当您连接时,您会看到一个在线列表,然后双击姓名即可打开聊天窗口。

服务器为每个客户端提供 2 个 serverSocket。

第一个是处理在线列表并更新和删除用户。第二个是处理消息。 (我单独做了两个,因为我不希望用户列表的名称与消息冲突)。

我的问题是,如果我想添加一项功能以便客户端可以互相发送文件,我应该为此创建第三个 ServerSocket 吗?

或者我构建的程序完全错误吗?

最佳答案

您构建应用程序的方式不正确。您需要一个套接字服务器来提取消息,然后将它们分派(dispatch)给一组工作人员。如果您愿意,您可以为每种消息类型配备一名工作人员。工作人员不应该了解有关网络层的任何信息。他们应该接受命令并返回一个值。向它们提供命令的网络类应该处理将结果写回客户端。这样,所有网络和安全逻辑都可以位于服务器类中,每个工作人员都可以专注于其专业任务,而无需了解网络。然后,您应该编写 junit 测试来单独测试每个工作线程,而不需要网络类。然后你的主程序只需创建和配置你的(经过junit测试!)工作线程,实例化服务器类,并给它你的工作线程,调用启动方法来启动你的服务器。欢迎来到软件工程,走向智慧的第一步是通过提出这样的问题来寻求学习。

编辑 我忘记回答文件处理问题:-) 真正的聊天服务可能对客户端(例如电话)的带宽较低。将大文件扔到另一个套接字上可能会使可用的客户端带宽饱和,从而使聊天成为一种糟糕的体验,同时许多文件尝试通过一个或多个套接字上传。一个好的方法是拉出文件的小块并添加到有界队列(LinkedBlockingQueue)中。然后查看队列中要与用户聊天命令交替发送的下一个文件 block 。在服务器上,网络类读取下一条消息,该消息可能是 block 或聊天命令,并将其分派(dispatch)给适当的工作人员。

可能有一个“启动文件上传命令”,它让网络服务器类为每个文件创建一个新的 FileUploadWorker 以允许并发上传。然后,在客户端上,可能有三个文件被分块到单个队列中,服务器上有三个工作人员,每个文件一个,而用户正在聊天,他们的聊天命令总是先于排队的文件 block 先发送到服务器其优先级低于实际聊天。

关于java聊天服务器多个服务器套接字用于处理不同的功能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26847471/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com