当OioClientSocketChannelFactory在构造的时候传入的参数线程池对象如Executors.newCachedThreadPool(),就是worker threads的来源。所以要保证指定的Executor 能提供足够数量的线程。
worker thread是延迟获得的(acquired lazily)并且在没有事务要处理时就会释放,所有yu该thread相关的资源都会释放,所以要优雅的关闭服务(先关闭所有的Channel,调用 ChannelGroup.close();而后调用releaseExternalResources()释放外部资源)。
要注意不要在所有的通道关闭前去关闭executor ,否则会发生RejectedExecutionException ,而且有些相关资源不会正常释放。
限制:通过OioClientSocketChannelFactory创建的SocketChannel 不支持异步操作,任何IO操作如连接,写等都已阻塞方式执行。