码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2019-04-22 00:14:15      阅读:174      评论:0      收藏:0      [点我收藏+]

标签:占用   获取   div   ref   利用   事件   ada   move   基本   

上接《服务端线程模型-线程池服务模型》(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(); // 删除选择键
            }
        }    

 

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

标签:占用   获取   div   ref   利用   事件   ada   move   基本   

原文地址:https://www.cnblogs.com/fudashi233/p/10747651.html

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