版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
网络编程模型与中间件设计思路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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024-2029年矿物颜料行业市场发展分析及竞争格局与投资战略研究报告
- 2024-2029年男士西裤企业创业板IPO上市工作咨询指导报告
- 2024-2034年中国传媒广告市场运行动态及行业投资潜力预测报告
- 2024-2034年中国交互式电子白板行业市场发展监测及投资战略规划研究报告
- 2024-2034年中国vea乳液行业市场现状分析及竞争格局与投资发展研究报告
- 2024-2034年中国PET泡沫(涤纶树脂)市场前景预测及未来发展趋势报告
- 2024-2034年中国LCD广告牌行业发展趋势及投资前景预测报告
- 2024-2034年中国CO2激光飞行打标机行业市场现状分析及竞争格局与投资发展研究报告
- 2024-2030年中国阻燃电线电缆行业发展战略研究及投资前景规划报告
- 2024-2030年中国节能装备行业市场研究分析及发展策略分析报告
- 药物合成反应_第六章_氧化反应
- 《嗜酸性肉芽肿性多血管炎诊治规范多学科专家共识》要点(完整版)
- 小班幼儿生活自理能力的现状研究
- 做一个懂得“示弱”的老师
- (完整版)生育服务证办理承诺书
- CO深冷分离操规(审核版
- 防漏堵漏理论与技术进展
- 临床试验中常见问题及解决办法2PPT课件
- 2021年银行人才队伍建设管理办法模版范文
- 10CrMo910+15CrMo焊接工艺卡
- 健全的网络与信息安全保障措施_包括网站安全保障措施、信息安全保密管理制度
评论
0/150
提交评论