Java网络通信中ServerSocket的设计优化方案
2019-04-11 09:16
771 查看
前言:在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请求就调用对应函数处理)
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接
您可能感兴趣的文章:
相关文章推荐
- 上机题目(0基础)- Java网络操作-Socket实现client和server端通信二(Java)
- Java网络编程ServerSocket的实现服务器与用户之间的通信的基本步骤
- [疯狂Java]NIO多路复用网络通信:Selector、SelectionKey、SelectableChannel(SocketChannel、ServerSocketChannel)
- JAVA的网络通信----SOCKET
- Java网络编程——Socket与ServerSocket
- Java网络编程基础 1 建立一个提供当前时间字符串的ServerSocket
- java学习之路——基于UDP的Socket网络通信实例
- java网络编程基础Socket通信应用
- 网络编程_TCP_Socket通信_聊天室_客户端多线程_群聊JAVA191-192
- SLG手游Java服务器的设计与开发——网络通信
- Java网络编程精解之ServerSocket用法详解一
- Java网络编程(ServerSocket和Socket)
- Java通信之Socket网络编程
- java网络编程——Socket和ServerSocket,套接字编程——简单聊天室
- java网络编程serversocket
- java网络socket编程(三)之ServerSocket服务器端
- SLG手游Java服务器的设计与开发——网络通信
- Java网络编程从入门到精通(28):获取ServerSocket信息的方法及FTP原理 推荐
- Java网络编程——使用NIO实现非阻塞Socket通信
- Java网络编程精解之ServerSocket用…