




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
网络编程模型与中间件设计思路Unix与Linux的5种IO模型1、阻塞I/O(BlockingI/O)2、非阻塞I/O(Non-BlockingI/O)3、I/O复用(select、poll、linux2.6种改进的epoll)(I/OMultiplexing)4、信号驱动IO(Singal-DriveI/O)5、异步I/O(AsynchronousI/O)(POSIX的aio_系列函数)POSIX:PortableOperatingSystemInterfaceofUnix可移植操作系统接口5种IO模型详细说明blocking:最简单的模型,使用最简单non-blocking:看似节省时间,实际上poll会占用更多的资源,需要和其他模型配合使用I/Omultiplexing:大名鼎鼎的select、epoll、kqueue。同时在多个描述符上进行等待、能超时(JAVA目前支持)signal-drivenI/O:真正的异步模式。(所谓异步,就是I/O事件发生的时候Kernel会利用Callback来通知处理数据的线程,然后该线程再去取数据。上面三个模式都是同步的,也就是说Kernel不会告诉用户程序什么时候I/Oready了。)。利用的sigaction来注册一个SIGIO的处理函数,然后系统通过SIGIO来callback信号处理函数。AsynchronousI/O:另外一种异步模式。主要的区别是,Kernel不仅通知用户进程I/O时间,同时把数据从Kernel空间复制到用户空间,当用户空间进行处理的时候,I/O已经处于“完成”状态了。(先提交给内核,完成之后通知)BlockingI/O无数据可读,则在调用处等待,直到有数据读可读才会执行后面的语句(阻塞当前线程)Non-BlockingI/O无数据读,则直接返回,继续后面的执行I/OMultiplexing若没有数据,则在相应函数在等待(select、epoll_wait等)Windows系统常用5种IO模型选择(Select)(多路复用)异步选择(WSAAsyncSelect)(采用WIN消息机制,通过消息通知I/O操作)事件选择(WSAEventSelect)(采用内核对象Event,通过内核信号状态来通知)重叠I/O(OverlappedI/O)(比事件选择更进一步,相应操作完成之后激发相应事件)完成端口(CompletionPort)共五种I/O模型(很复杂,更更进一步,相应I/O操作完成之后放入队列,最高效率)JAVA网络编程模型(IO与NIO)同步I/ONIO(多路复用)AIO(还没有实现,JavaSE7.0可能会实现)NIO实现机制Windows:select(无法支持大量连接,JAVA服务程序不适合跑在win下)Linux:epoll(能支持大量连接)FreeBSD:kqueue(比select强)网络服务器软件基本结构ReadRequestDecodeRequestProcessServiceEncodeReplySendReply基本结构相同,但处理模型非常多,软件设计上非常复杂JAVA网络服务器软件基本结构一JAVA网络服务器软件基本结构二JAVA网络服务器软件基本结构三JAVA网络服务器软件基本结构四中间件协议设计中间件接口设计publicinterfaceFunction{publicvoidinvoke(IContextcontext)throwsInvokeException;}所有的业务功能都必须继承此接口。publicinterfaceIContext{/***获得程序的上下文接口**@return*/publicIAppContextgetAppContext();/***返回数据源服务接口**@return*/publicIDBServicegetDBService();/***获得请求对象**@return*/publicIRequestgetRequest();/***获得响应对象**@return
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年农产品质量安全追溯体系在农村电商中的应用与效果评估报告
- 易溶盐考试题及答案
- 2021入党题目及答案
- 2018年执业药师考试题及答案
- 2017叉车理论考试题及答案
- 2016高考试题及答案
- 【高考物理】2026高考 导与练总复习物理一轮(基础版)第一章 第2讲 匀变速直线运动的规律含答案
- 5g阅读题库及答案
- 期末考试卷一-2024-2025学年语文四年级下册统编版
- 2025年农产品保鲜技术发展趋势与鉴定研究
- 集团集中采购管理制度(试运行)
- GB/T 5210-2006色漆和清漆拉开法附着力试验
- GB/T 39165-2020电阻点焊及凸焊接头的剥离和凿离试验方法
- GB/T 20698-200656%2甲4氯钠可溶粉剂
- 行政事业单位经济业务不相容岗位相分离控制制度模板
- 统计学原理试题与答案
- (妇产科学)第十八章 女性生殖系统炎症课件
- 立式加工中心的基本操作专题培训课件
- 一例慢阻肺病人护理个案
- 阿克苏地区生态环境准入清单
- 产品创新设计与实践完整版课件全套ppt教学教程电子教案讲义最全(最新)
评论
0/150
提交评论