首页 > Web开发 > 详细

Netty3 源码分析 - OioClientSocketChannelFactory

时间:2014-09-11 15:26:32      阅读:346      评论:0      收藏:0      [点我收藏+]


     是一个ClientSocketChannelFactory 的实现,基于SocketChannel的阻塞方式的客户端通道。使用的是传统的阻塞IO API,特点是能得到好的吞吐量和低延迟,当需要服务的连接数少的时候。(联系NIO和OIO的区别)

     在OioClientSocketChannelFactory中只有一种线程类型,worker threads。每个连接的通道有一个专用的worker,就是传统的IO模型。(见下图)

     当OioClientSocketChannelFactory在构造的时候传入的参数线程池对象如Executors.newCachedThreadPool(),就是worker threads的来源。所以要保证指定的Executor 能提供足够数量的线程。
worker thread是延迟获得的(acquired lazily)并且在没有事务要处理时就会释放,所有yu该thread相关的资源都会释放,所以要优雅的关闭服务(先关闭所有的Channel,调用 ChannelGroup.close();而后调用releaseExternalResources()释放外部资源)。

     要注意不要在所有的通道关闭前去关闭executor ,否则会发生RejectedExecutionException ,而且有些相关资源不会正常释放。
限制:通过OioClientSocketChannelFactory创建的SocketChannel 不支持异步操作,任何IO操作如连接,写等都已阻塞方式执行。
bubuko.com,布布扣












Netty3 源码分析 - OioClientSocketChannelFactory

原文:http://blog.csdn.net/vonzhoufz/article/details/39205709

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!