Netty是一个NIO客户端-服务器框架,在NIO模式下,线程直接返回结果,当缓冲区准备好数据之后再异步线程回调客户端消息处理。不会像BIO一样阻塞线程(I/O)并持续等待被调用方准备好响应数据才返回。
但是在某些使用socket通讯的场景下,使用了NIO的netty,但是调用方必须在当前线程等待服务返回业务处理状态之后才能进行后续的操作,那么就需要用到BIO模式,那么除了使用java原生的BIO,这里介绍一种使用CountDownLatch+Netty来模拟BIO的实现。
下面介绍下实现过程和伪代码,文章末尾提供完整示例下载地址。代码仅供学习。
-
环境:netty4.1.27、eclipse,jdk1.8;
-
流程设计
-
原理说明
-
1、在客户端发送数据给服务端时(本实例服务端采用java原生socket简单实现),通过uuid生成本次发送的请求的唯一标识(sn),并将此sn附在发送数据的头部位置(服务端返回时需要带上此s