当前位置: 首页 > 编程笔记 >

Java网络通信中ServerSocket的设计优化方案

邹浩
2023-03-14
本文向大家介绍Java网络通信中ServerSocket的设计优化方案,包括了Java网络通信中ServerSocket的设计优化方案的使用技巧和注意事项,需要的朋友参考一下

前言:在java的网络通信中,两个不同节点的主机想要进行通信则可以通过建立Socket对象(相当于客户端主机,向服务端请求发送信息)和ServerSocket对象(相当于服务端主机,接收客户端的连接请求并回复信息)实现。

1:创建一个Socket对象

Socket socket = new Socket("IP",port);

指定将要连接的服务端的ip地址和端口号来创建一个Socket对象,在创建结束之后便可对其进行输出、输入操作。

2:创建一个ServerSocket对象

ServerSocket sever = new ServerSocket(port); //此端口为客户端连接的端口
Socket connnection = server.accept(); //阻塞在此监听上方的端口,一但有连接请求就做出处理。

创建一个新的ServerSocket对象,并让这个对象阻塞监听客户端连接的指定的端口,一但有新的连接请求则做出处理。

基本的一个关系是:Socket ------------------->ServerSocket

此时只要来一个连接服务端就阻塞做出处理,等到处理结束之后重新处以监听端口状态,要是又来一个新的连接请求则......一直往复处理动作。明显的缺点是效率低,每次只能处理一个请求,并且是阻塞处理状态。 

优化处理:

  • BIO中开启多线程,每来一个请求服务端就开启一个线程处理。(优点是可以提高效率,但是缺点也很明显:优点大量几乎同时入站连接可能导致它生成极大数量的线程。最终,java虚拟机会消耗内存二崩溃)。
  • 对于上面的方案做出改进:BIO中使用线程池管理线程。(可以处理效率同时避免了服务器因为高并发的连接而崩溃)。
  • 使用NIO。(NIO虽然也是单个线程去处理连接请求,但是不会阻塞,会不停地轮询是否有就绪的事件,所以处理的顺序和连接请求的先后顺序无关,与请求数据到来的先后顺序有关。一个线程中就可以调用多路复用接口(select)阻塞同时监听来自多个客户端的IO请求,一旦有收到IO请求就调用对应函数处理)

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对小牛知识库的支持。如果你想了解更多相关内容请查看下面相关链接

 类似资料:
  • 问题内容: 我和一个朋友正在使用客户端/服务器- 体系结构进行Java游戏。它运行良好,但是我遇到了问题。我们使用TCP套接字在服务器和客户端之间建立网络。我们的网络协议未加密,只有看管流的人才能阅读。 我们考虑过如何对它应用某种加密技术以隐藏登录信息并防止人们编写自己的客户端。但是,基本的事情,例如增加/减少字节,似乎很容易弄清楚。 用于加密游戏(或至少游戏登录信息)的网络通信的常用方法是什么?

  • 用途: 提供对网络通信的访问 Addressing, Protocol Families and Socket Types Looking up Hosts on the Network Finding Service Information Looking Up Server Addresses IP Address Representations TCP/IP Client and Serve

  • 主要内容:前期回顾前期回顾 因此很重要:this.client.poll(pollTimeout, now); 在步骤二的ready()里面,建立连接之前需要做网络的初始化: 典型的NIO操作 再调用 selector.poll()

  • 我试图建立一个多人游戏与游戏服务器运行最多4个客户端,使用java套接字和ServerSocket。在此代码中,我将客户端的数量限制在1个,并对播放器和服务器使用阻塞I/O模型。 游戏服务器线程(实现Runnable)使用套接字输入流从每个客户端接收“Snake object to Snake[i]”和“char变量to DirInput”,并使用套接字输出流发送“Snake object Arr

  • 我正在学习神经网络和反向传播。我想我了解网络是如何工作的,在输入、输出、隐藏层、权重、偏差等方面。但是,我仍然不完全了解如何设计一个网络来适应一个问题。IE:假设我想要一个神经网络来学习如何演奏曲子,我该如何把这个问题转化为神经网络的设计呢?欢呼:)

  • 使用QQ轻游戏后台 QQ轻游戏后台用现成的房间逻辑,开发者可以使用进行房间创建、加入、离开、以及自带的帧同步以及消息同步方案。 使用QQ轻游戏后台详情跳转至此处 自建后台 使用自建后台,开发者可以使用引擎自带的 BK.WebSocket、BK.Socket、BK.HttpUtil三种方法进行后台数据的交换。 使用自建后台详情跳转至此处 因为自建后台的房间概念QQ轻游戏并不理解,为在聊天窗中模拟房间