java IO
Y_YoungSun
技术宅男
展开
-
Epoll在Java Nio中的实现
Nio与Epoll一直对nio和epoll没有系统的认识,最近看了下openjdk,简单的做个记录。Linux2.6之后支持epoll windows支持select而不支持epoll 不同系统下nio的实现是不一样的,包括Sunos linux 和windows select的复杂度为O(N) select有最大fd限制,默认为1024 修改sys/select.h可以改变se...转载 2018-07-27 16:54:51 · 13968 阅读 · 0 评论 -
高并发网络编程之epoll详解
在linux 没有实现epoll事件驱动机制之前,我们一般选择用select或者poll等IO多路复用的方法来实现并发服务程序。在大数据、高并发、集群等一些名词唱得火热之年代,select和poll的用武之地越来越有限,风头已经被epoll占尽。本文便来介绍epoll的实现机制,并附带讲解一下select和poll。通过对比其不同的实现机制,真正理解为何epoll能实现高并发。select...转载 2018-07-27 16:56:12 · 172 阅读 · 0 评论 -
[转]我读过最好的Epoll模型讲解
首先我们来定义流的概念,一个流可以是文件,socket,pipe等等可以进行I/O操作的内核对象。不管是文件,还是套接字,还是管道,我们都可以把他们看作流。之后我们来讨论I/O的操作,通过read,我们可以从流中读入数据;通过write,我们可以往流写入数据。现在假定一个情形,我们需要从流中读数据,但是流中还没有数据,(典型的例子为,客户端要从socket读如数据,但是服务器还没有把数据传...转载 2018-07-27 16:57:34 · 180 阅读 · 0 评论 -
NIO、BIO、AIO的原理及区别与应用场景
在高性能的IO体系设计中,有几个名词概念常常会使我们感到迷惑不解。具体如下: 序号 问题 1 什么是同步? 2 什么是异步? 3 什么是阻塞? 4 什么是非阻塞? 5 什么是同步阻塞? 6 什么是同步非阻塞? 7 什么是异步阻塞? 8 什么是异步非阻塞? 在弄清楚上面的几个问题之前,我们首先得明白什么是...转载 2018-07-27 16:59:47 · 283 阅读 · 0 评论 -
Java NIO:浅析I/O模型
也许很多朋友在学习NIO的时候都会感觉有点吃力,对里面的很多概念都感觉不是那么明朗。在进入Java NIO编程之前,我们今天先来讨论一些比较基础的知识:I/O模型。下面本文先从同步和异步的概念 说起,然后接着阐述了阻塞和非阻塞的区别,接着介绍了阻塞IO和非阻塞IO的区别,然后介绍了同步IO和异步IO的区别,接下来介绍了5种IO模型,最后介绍了两种和高性能IO设计相关的设计模式(Reactor和Pr...转载 2018-08-28 12:49:52 · 100 阅读 · 0 评论 -
IO模型之IO多路复用 异步IO select poll epoll 的用法
IO 模型之 多路复用 IO多路复用IOIO multiplexing 这个词可能有点陌生,但是如果我说 select/epoll ,大概就都能明白了。有些地方也称这种IO方式为 事件驱动IO (event driven IO) 。我们都知道,select/epoll的好处就在于单个process就可以同时处理多个网络连接的IO。它的基本原理就是select/epoll这个functi...转载 2018-08-28 13:45:15 · 151 阅读 · 0 评论 -
I/O模型与多路复用
同步、异步、阻塞、非阻塞同步 & 异步同步与异步是针对多个事件(线程/进程)来说的。如果事件A需要等待事件B的完成才能完成,这种串行执行机制可以说是同步的,这是一种可靠的任务序列,要么都成功,要么都失败。 如果事件B的执行不需要依赖事件A的完成结果,这种并行的执行机制可以说是异步的。事件B不确定事件A是否真正完成,所以是不可靠的任务序列。同步异步可以理解为多个事件的执行方式...转载 2018-08-28 14:04:08 · 3761 阅读 · 0 评论 -
解读I/O多路复用技术
前言当我们要编写一个echo服务器程序的时候,需要对用户从标准输入键入的交互命令做出响应。在这种情况下,服务器必须响应两个相互独立的I/O事件:1)网络客户端发起网络连接请求,2)用户在键盘上键入命令行。我们先等待哪个事件呢?没有哪个选择是理想的。如果在acceptor中等待一个连接请求,我们就不能响应输入的命令。类似地,如果在read中等待一个输入命令,我们就不能响应任何连接请求。针对这种困...转载 2018-08-28 14:12:11 · 264 阅读 · 0 评论