随笔分类 -  IO线程模型

摘要:介绍 Java 的zero copy多在网络应用程序中使用。Java的libaries在linux和unix中支持zero copy,关键的api是java.nio.channel.FileChannel的transferTo(),transferFrom()方法。我们可以用这两个方法来把bytes 阅读全文
posted @ 2018-10-19 17:55 kaleidoscopic 阅读(655) 评论(0) 推荐(0) 编辑
摘要:反应器设计模式(Reactor pattern)是一种为处理服务请求并发 提交到一个或者多个服务处理程序的事件设计模式。当请求抵达后,服务处理程序使用解多路分配策略,然后同步地派发这些请求至相关的请求处理程序。 The reactor design pattern is an event handl 阅读全文
posted @ 2018-10-19 17:48 kaleidoscopic 阅读(256) 评论(0) 推荐(0) 编辑
摘要:Netty是一个高性能、异步事件驱动的NIO框架,它提供了对TCP、UDP和文件传输的支持,作为一个异步NIO框架,Netty的所有IO操作都是异步非阻塞的,通过Future-Listener机制,用户可以方便的主动获取或者通过通知机制获得IO操作结果。 作为当前最流行的NIO框架,Netty在互联 阅读全文
posted @ 2018-10-19 17:37 kaleidoscopic 阅读(900) 评论(0) 推荐(0) 编辑
摘要:同步(synchronous) IO和异步(asynchronous) IO,阻塞(blocking) IO和非阻塞(non-blocking)IO分别是什么,到底有什么区别?这个问题其实不同的人给出的答案都可能不同,比如wiki,就认为asynchronous IO和non-blocking IO 阅读全文
posted @ 2018-08-17 17:02 kaleidoscopic 阅读(268) 评论(0) 推荐(0) 编辑
摘要:一、BIO的理解 首先我们通过通信模型图来熟悉下BIO的服务端通信模型:采用BIO通信模型的服务端,通常由一个独立的Acceptor线程负责监听客户端的连接,它接收到客户端的连接请求之后为每个客户端创建一个新的线程进行链路处理,处理完成之后,通过输出流返回应答给客户端,线程销毁。这就是典型的一请求一 阅读全文
posted @ 2018-08-17 16:35 kaleidoscopic 阅读(515) 评论(0) 推荐(0) 编辑

点击右上角即可分享
微信分享提示