利用CountDownLatch实现基于netty的“BIO“

本文介绍了如何在使用Netty时,通过CountDownLatch来模拟BIO(阻塞I/O)模式。在NIO模式下,Netty通常避免线程阻塞,但在特定场景下需要等待服务端返回业务处理状态。通过生成请求唯一标识,配合CountDownLatch在客户端进行阻塞,服务端处理完毕后再唤醒客户端,实现了类似BIO的效果。文章提供了关键代码片段和完整示例的下载方式。

​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附在发送数据的头部位置(服务端返回时需要带上此sn),同时客户端产生一个CountDownLatch和当前sn绑定。

  • 2、发送成功后,通过CountDownLatch.await阻塞当前线程。

  • 3、服务端接收数据并处理相关完后,封装含客户端sn的返回数据发送给

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值