打赏

随笔分类 -  IO

摘要:分布式rpc框架有很多,比如dubbo,netty,还有很多其他的产品。但他们大部分都是基于nio的, nio是非阻塞的io,那么它的内部机制是怎么实现的呢。 1.由一个专门的线程处理所有IO事件,并负责分发。 2.事件驱动机制,事件到来的时候触发操作,不需要阻塞的监视事件。 3.线程之前通过wai 阅读全文
posted @ 2019-04-23 14:56 海米傻傻 阅读(2244) 评论(1) 推荐(1) 编辑
摘要:NIO VS IO NIO: 面向缓存; 非阻塞的; selector IO: 面向流; 阻塞的; 无 JAVA IO Java IO: Reading data from a blocking stream. Java IO: A classic IO server design - one co 阅读全文
posted @ 2019-04-23 14:21 海米傻傻 阅读(335) 评论(0) 推荐(0) 编辑
摘要:1. 概述 Java IO一般包含两个部分: 1.java.io包中堵塞型IO; 2.java.nio包中的非堵塞型IO,通常称为New IO。 java.io包下,分为四大块近80个类: 1、基于字节操作的I/O接口:InputStream和OutputStream 2、基于字符操作的I/O接口: 阅读全文
posted @ 2019-04-23 14:19 海米傻傻 阅读(499) 评论(1) 推荐(0) 编辑
摘要:核心部分 NIO( New Input/ Output) , 引入了一种基于通道和缓冲区的 I/O 方式,NIO 是一种同步非阻塞的 IO 模型。同步是指线程不断轮询 IO 事件是否就绪,非阻塞是指线程在等待 IO 的时候,可以同时做其他任务。同步的核心就是 Selector,Selector 代替 阅读全文
posted @ 2019-04-23 14:19 海米傻傻 阅读(1758) 评论(0) 推荐(0) 编辑
摘要:不同的操作系统实现的io策略可能不一样,即使是同一个操作系统也可能存在多重io策略,常见如linux上的select,poll,epoll,面对这么多不同类型的io接口,这里需要一层抽象api来完成,所以就演变出来两种高性能的io的设计模式,分别是Reactor(同步IO)和Proactor(异步I 阅读全文
posted @ 2019-04-23 14:17 海米傻傻 阅读(416) 评论(0) 推荐(0) 编辑
摘要:一、传统的BIO 网络编程的基本模型是Client/Server模型,也就是两个进程之间进行相互通信,其中服务端提供位置信息(绑定的IP地址和监听端口),客户端通过连接操作向服务端监听的地址发起连接请求,通过三次握手建立连接,如果连接建立成功,双方就可以通过网络套接字(Socket)进行通信。 在基 阅读全文
posted @ 2019-04-23 14:17 海米傻傻 阅读(1089) 评论(0) 推荐(0) 编辑
摘要:1. Unix的五种I/O模型 从上往下:阻塞程度(高 低)I/O效率 (低 高) 阻塞I/O(Blocking I/O):传统的IO模型 非阻塞I/O(Non-Blocking I/O): 注意这里所说的NIO并非Java的NIO(New IO)库。 I/O多路复用(I/O Multiplexin 阅读全文
posted @ 2019-04-23 14:17 海米傻傻 阅读(293) 评论(0) 推荐(0) 编辑
摘要:1. IO模型矩阵 基本 Linux I/O 模型的简单矩阵: 同步与异步:描述的是用户线程与内核的交互方式。 同步IO和异步IO的区别就在于:数据拷贝的时候进程是否阻塞! 同步是指用户线程发起IO请求后需要等待或者轮询内核IO操作完成后才能继续执行;(Blocking IO、Non-Blockin 阅读全文
posted @ 2019-04-23 14:16 海米傻傻 阅读(321) 评论(0) 推荐(0) 编辑
摘要:IO多路复用之select、poll、epoll IO多路复用:通过一种机制,一个进程可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪),能够通知程序进行相应的读写操作。 应用:适用于针对大量的io请求的情况,对于服务器必须在同时处理来自客户端的大量的io操作的时候,就非常适合 与多进 阅读全文
posted @ 2019-04-23 14:16 海米傻傻 阅读(1317) 评论(0) 推荐(0) 编辑