`
jayjayjays
  • 浏览: 215342 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

NIO socket服务器注意的几点.

    博客分类:
  • java
阅读更多

     当你看到这篇文章的时候,也许是像我一样,以经用google搜了一大堆socket的例子运行调试成功了.但是在实际应用中有几点需要注意的地方.要不然你的服务器还是一大堆的bug.

 

1.注册读事件.

     客户端第刚链接过来的时候注册一次读事件.

     已后就是在每次写完数据之后再去注册读事件.

 

2.注册写事件.

     每次处理过逻辑之后,注册写事件,然后把要返回的结果socketChannel.write(responseLineBuffer)写出去.

 

3.在读数据的时候注意.

 

 

 

 

//首先客户端发来的数据应该带有标示这次发送过来的数据大小.

int responseSize;

//读来的数据缓冲区.

ByteBuffer requestLineBuffer = ByteBuffer.allocate(1024);

  

*比如说客户端发过来1024个字节.这样的话正好 requestLineBuffer 一次读到1024个字节.这时 responseSize==requestLineBuffer里面数据的大小. 这正是你需要的完整数据.

 

*如果客户端发送过来100个字节.这时responseSize<requestLineBuffer里面数据的大小.这时你就需要判断当读到100个字节的时候就不要再往下读了,即使再读的话也是空数据.

 

前两种情况正是你所希望的,responseSize<=requestLineBuffer里面数据的大小.

 

*如果客户端发送过来2048个字节,第一次最多也就读1024个字节的数据.这时responseSize>requestLineBuffer,你就要判断如果第一次没有把数据读完整的话,还要再去把剩下的1024个字节的数读过来.

 

这种情况也许你已经想到了.但下面还有2种诡异的情况.

 

*如果客户端发送过来 2048 个字节,但是分2次或多次发送过来,比如说前两次读到 1548 个字节,这时你判断发现还没有接收到完整数据但再去用int count = socketChannel.read(requestLineBuffer);读,就是读不到数据.这样的话你就需要把这次读到的数据保存下来,再注册一个读的事件去读,等到下次把剩下的 500 个字节 数据读过来后再去处理逻辑.这样的情况就是socketChannel.read的数据并不是一次把数据读到的,而是分多次.

 

*最后一种情况就是 如果客户端发送过来 5000 个字节,但是每次请求的数据只有 1000 个字节,这说明客户端发送太快,或是服务器处理太慢,系统把这5次的请求的数据加到一起了.这时你就要把这5个请求一个一个的分别取出来一个一个的去处理相应的逻辑.

 

 

//注销写事件

key.interestOps(key.interestOps()&~SelectionKey.OP_WRITE);
//注销读事件

key.interestOps(key.interestOps()&~SelectionKey.OP_READ); 



key.cancel();

 

//客户端关闭判断. 

int count = socketChannel.read(requestLineBuffer);
if (count <= -1) {
    close();

 

 

 

8
0
分享到:
评论
3 楼 ooo456mmm 2014-03-11  
说的对,如果用Mina框架来处理,要简单很多了
2 楼 liudeh_009 2012-07-25  
总结得很好
1 楼 freepig 2008-12-09  
让MINA去做这些事情吧

相关推荐

    一般Socket客户端与Mina NIO Socket客户端对比示例

    在对比这两者时,我们需要注意以下几点: 1. 性能:Mina NIO由于其非阻塞特性,在高并发环境下性能更优,而普通Socket客户端在低并发或响应时间要求不高的场景下可能更具优势。 2. 并发能力:Mina NIO的并发能力...

    Java多线程机制及其在socket编程中的应用.pdf

    3. 线程池在socket服务器中的应用:由于创建线程是有开销的,使用线程池可以减少资源消耗,提高性能。服务器可以预先创建一定数量的线程,并将这些线程存储在池中,当需要处理新的连接时,从池中取出一个线程即可。 ...

    java socket nio 研究

    Java Socket和NIO(非阻塞I/O)是Java编程中的重要部分,它们在构建高性能、高并发的网络应用程序中发挥着关键作用。Socket是基于TCP/IP协议的应用层接口,而NIO则是一种I/O模型,它提供了不同于传统阻塞I/O的处理...

    Socket中InputStream的read方法的阻塞特性

    Socket中的InputStream的`read`方法是Java网络编程中一个核心的概念,它在处理客户端与服务器之间的数据传输时起着至关重要的作用。`read`方法的阻塞特性是其设计的一个重要特点,也是理解多线程和并发编程的关键点...

    java socket开发即时通讯服务器

    协议设计应考虑以下几点: 1. **消息头**:标识消息的类型、长度等元信息。 2. **消息体**:承载实际的数据内容。 3. **错误处理**:如何处理网络异常、解析错误等问题。 **四、心跳机制**:保持连接活跃,检测...

    SocketTool.app.zip

    在Socket编程中,主要涉及以下几个关键知识点: 1. **套接字(Socket)接口**:这是操作系统提供的编程接口,允许应用程序创建、配置和使用网络连接。在不同的操作系统上,如Windows和Unix/Linux,Socket接口略有...

    多线程NIO客户端实例

    在深入解析这段代码之前,我们先来理解一下几个核心的概念:**多线程**、**NIO(Non-blocking I/O)**以及它们如何协同工作在客户端编程中。 - **多线程**:在Java中,多线程允许程序同时执行多个线程,每个线程...

    java nio 网络编程指南

    Java NIO API的出现解决了这一问题,它允许服务器使用一个或少数几个线程就能高效地处理成百上千的客户端连接。关键在于NIO中的非阻塞特性,它使服务器能够同时监听多个客户端的读写事件,无需为每个连接分配单独的...

    Socket通信实例源代码

    在编写Socket通信代码时,需要注意以下几点技巧: 1. 异步处理:服务器可能需要同时处理多个客户端连接,因此,通常会使用多线程或异步处理机制来并发地处理客户端请求。 2. 错误处理:网络通信中可能会出现各种...

    一个基于Socket的Android聊天室(java实现服务器).zip

    Android聊天室的实现通常涉及以下几个关键知识点: 1. **Socket编程**:Java中的Socket类和ServerSocket类是进行网络通信的基础。ServerSocket在服务器端创建并监听特定端口,等待客户端的连接请求;Socket则在...

    安卓Android源码——Android版FTP服务器 SwiFTP源代码.zip

    在SwiFTP中,主要涉及以下几个关键知识点: 1. **服务(Service)**:Android服务是后台运行的组件,它不与用户界面交互。SwiFTP通过创建一个`IntentService`来启动FTP服务器,这样即使用户离开应用程序,服务也能...

    手写 tomcat nio

    手写Tomcat NIO,意味着我们要构建一个基于NIO的自定义Web服务器,这涉及到以下几个关键点: 1. **Socket通道**:在Java NIO中,SocketChannel是用于网络通信的通道,它可以从套接字读取数据或将数据写入套接字。在...

    java异步socket调用.pdf

    Java异步Socket调用的知识点涵盖了Java网络编程中的关键概念和实践技巧,特别是在处理异步通信时使用的技术和方法。在讨论这个话题时,我们通常会涉及到以下几个重要方面: 1. 同步与异步通信: 同步通信指的是...

    socket长连接,netty服务器与android源码

    Socket长连接和Netty框架是网络编程中的重要概念,尤其在Android应用开发和服务器通信中扮演着关键角色。本文将深入探讨这两个主题,并通过提供的源码进行实例解析。 首先,让我们了解一下Socket。Socket是网络通信...

    基于java语言实现的游戏服务器框架.zip

    以上就是基于Java语言实现的游戏服务器框架的一些核心知识点,这些技术和理念可以帮助我们构建出高效、可扩展且易于维护的游戏后端服务。在实际开发过程中,还需要结合具体的业务需求和项目规模进行优化和调整,以...

    Java在游戏服务器开发中的应用.docx

    此外,游戏服务器开发中还需要关注以下几点: 1. **性能优化**:通过缓存、异步处理、负载均衡等手段提高服务器性能。 2. **容错与恢复**:设计冗余和故障转移机制,确保服务的高可用性。 3. **安全防护**:防止...

    高级 socket 通信

    在高级Socket通信中,我们关注以下几点: 1. **多路复用**:SocketChannel结合Selector,服务器可以实现多路复用,即一个线程可以同时管理多个连接,提高了服务器的并发能力。这对于高流量的网络应用来说至关重要。...

    Java Socket传输图片源代码

    "Java Socket传输图片源代码"这个主题涵盖了以下几个关键知识点: 1. **Java Socket基础**: - Socket是TCP/IP协议族的一部分,用于在网络应用程序之间建立双向通信通道。Java的`java.net.Socket`类和`...

Global site tag (gtag.js) - Google Analytics