温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java网络通信中ServerSocket如何优化

发布时间:2021-09-09 11:25:31 来源:亿速云 阅读:172 作者:小新 栏目:编程语言

这篇文章主要介绍了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网络通信中ServerSocket如何优化”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI