




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
网络编程模型与中间件设计思路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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 广州卫生职业技术学院《国际共产主义运动史》2023-2024学年第一学期期末试卷
- 合肥师范学院《创意图像设计》2023-2024学年第二学期期末试卷
- 陕西青年职业学院《数据库技术MySQ》2023-2024学年第二学期期末试卷
- 预防性驾驶与防御性驾驶
- 避险逃生知识竞答
- 大学生商业计划创业
- 预防天然气爆炸
- 防雾霾小知识
- 脑积水业务学习及护理查房
- 音乐基础知识讲解
- 中央2024年农业农村部机关服务局招聘事业编制工作人员笔试历年典型考点(频考版试卷)附带答案详解
- 博物馆疫情防控方案与参观人数控制
- 2024年通讯机房、设备安全操作规程(2篇)
- 四川开放大学2024年秋《土木工程CAD》形考作业1-2终考答案
- 形势与政策总体国家安全观
- 智能运维知识库建设方案设计与实施规划
- 《即时检验(POCT)室内质量控制指南》
- 互联网+大学创新创业大赛金奖计划书(完整详细版)
- 中国高血压防治指南(2024年修订版)要点解读
- 室外消防管道保温施工方案
- 《积极心理学(第3版)》 课件 第3章 积极情绪的价值
评论
0/150
提交评论