码迷,mamicode.com
首页 > Web开发 > 详细

Netty3 源码分析 - OioClientSocketChannelFactory

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

标签:oioclientsocketchann   clientsocketchannelf   socketchannel   


     是一个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

标签:oioclientsocketchann   clientsocketchannelf   socketchannel   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!