服务端线程模型-NIO服务模型

上接《服务端线程模型-线程池服务模型》(https://www.cnblogs.com/fudashi233/p/10549221.html)。

这篇分享从最初的单线程服务模型一直演进到线程池服务模型,充分发挥出了现在多核CPU机器的优势,但是当面对万级别的qps时,仍然可能因为线程池打满而拒绝掉大量请求。

比如可能有不少请求需要大量IO资源,导致IO阻塞的耗时较长,这就会导致其一直占用宝贵的线程池资源,导致后续的请求的响应时间长。

这时就需要使用NIO服务模型了,基于Selector的事件监听机制,他会轮询已经建立的Socket,将准备好了的请求交给CPU处理,充分利用线程资源。

 

 

 

基本的代码模型如下所示

while (selector.select() > 0) { // 轮询/监听底层Socket
            Iterator<SelectionKey> iterator = selector.selectedKeys().iterator();
            while (iterator.hasNext()) {
                SelectionKey selectionKey = iterator.next(); // 获取准备就绪的事件
                if (selectionKey.isAcceptable()) { // 发生客户端连接事件

                } else if (selectionKey.isReadable()) { // 发生读事件

                    }
                } else if (selectionKey.isWritable()) { // 发生写事件

                }
                selectionKey.cancel();
                selectionKey.channel().close();
                iterator.remove(); // 删除选择键
            }
        }    

 

posted @ 2019-04-21 23:07  Fudashi233  阅读(132)  评论(0编辑  收藏  举报