是一个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操作如连接,写等都已阻塞方式执行。