web服务处理过程,各种I/O模型详解,

简介:

一, 进程,线程?

进程是具有一定独立功能的,在计算机中已经运行的程序的实体。在linux2.4以前,进程是基本运作的单位,在只是线程的系统中,线程才是最基本的运作单位,而进程只是线程的容器,程序本身只是指令,数据及其组织形式的描述,进程才是程序的真正运行实例。若干进程有可能在同一程序相关,且每个进程皆可以同步或异步的方式独立运行。现代计算机系统可在同一时间内以进程的形式将多个程序加载到储存器中,并借由时间共享,以在一个处理器上表现出同时运行的感觉,同样的,使用多线程技术(每一个线程都代表一个进程内的一个独立执行上下文)的操作系统或计算机架构,同样程序的平行线程,可在多cpu主机或网络上真正同时运行。

二, 常见Web服务方式

  1.       一个web请求处理的过程:

1.png

(1),用户发起请求到服务器网卡;

(2),服务器网卡接收到请求后,转交给内核处理;

(3),内核根据请求对应的套接字,将请求交给工作在用户控件的web服务器进程;

(4),Web服务器进程根据用户请求,向内核进行系统调用,申请获取相应的资源;

(5),内核发现web服务器进程请求的是一个放存在硬盘上的资源,因此通过驱动程序连接磁盘;

(6),内核调度磁盘,获取需要的资源;

(7),内核将资源存放在自己的缓冲区中,并通知web服务器进程;

(8),web服务器进程通过系统调用取得资源,并将其复制到进程自己的缓冲区中;

(9),web服务器进程形成响应,通过系统调用再次发给内核以响应自己用户请求;

(10),内核将响应发给网卡;

(11),网卡发送响应给用户;

简单来说:用户请求—>送达用户空间—>系统调用—>内核空间—>内核到磁盘上读取网页的资源—>返回到用户空间—>响应给用户。

2.三种工作模型比较:

多进程方式:为每个请求启动一个进程来处理,由于在操作系统中,生成进程,销毁进程,进程间切换都很耗费CPU和内存,当负载高时,性能会明显降低。

优点:稳定性!由于采用独立进程处理地理请求,而进程之间是独立的,单个进程问题不会影响其他进程,因此稳定性是最好的

缺点:占用资源!当请求过大时,需要大量的进程处理请求,进程生成,切换开销很大,而且进程间资源是独立的,造成内存重复利用。

多线程方式:一个进程中用多个线程处理用户请求,由于线程开销明显小于进程,而且部分资源还可以共享,因此效率较高。

优点:开销较小!线程部分数据是共享的,且线程生成与线程间的切换所需要的资源开销比进程间切换小的多

缺点:稳定性!线程切换过快可能造成线程抖动,且线程过多会造成服务器不稳定。

异步方式:使用非阻塞方式处理请求,是三种方式中开销最小的,但异步方式虽然效率高,但要求也高,因为多任务之间的调度如果出现故障,就可能出现整体故障,因此使用异步工作的,一般是一些功能相对简单,但却符合服务器任务调度,且代码中没有影响调度的错误代码存在的程序。

优点:性能最好!一个进程或线程处理多个请求,不需要额外开销,性能最好,资源占用最低。

缺点:稳定性!某个进程或线程出错,可能导致大量请求无法处理,甚至导致整个服务器宕机。

三, 各种I/O模型详解

通过一的连接分析,我们知道工作在用户空间的web服务器进程是无法直接操作I/O的,需要通过系统调用进行。

2.png

进程向内核进行系统调用申请I/O,内核将资源从IO调度到内核的buffer中(wait阶段),内核还需将数据从内核buffer中复制(copy阶段)到web服务器进程所在的用户空间,才算完成一次IO调度,这几个阶段都是需要时间的,根据wait和copy阶段的处理等待机制不同,可将I/O动作分为如下五中模式:

阻塞I/O:所有过程全阻塞

非阻塞I/O:如果没有数据buffer,则立即返回

I/O复用(select和poll):在wait和copy阶段分别阻塞(select和poll)

信号驱动I/O:在wait阶段不阻塞,但在copy阶段阻塞(信号驱动I/O,既通知)

异步I/O:完全无阻塞方式每当I/O完成时提供信号

 

阻塞和非阻塞:

阻塞和非阻塞指的是执行一个操作是等操作结束再返回,还是马上返回。

阻塞:在出菜窗口等待,直到厨师炒完菜后将菜送到窗口,然后服务员再将菜送到用户手中

非阻塞:等一会再到窗口来问厨师,某个菜好了没,如果没有就先处理其他事情,等会再去问一次;

 

 

同步和异步:

同步和异步是另外一个概念,它是事件本身的一个属性。

服务员直接和厨师打交道,菜出来没出来,服务员直接指导,但只有当厨师将菜送到服务员手上这个过程才算正常完成,这就是同步事件,同步只能以阻塞的方式去做。

有些餐馆有专门的传菜人员,当厨师炒好菜后,传菜员将菜送到传菜窗口,并通知服务员,这就变成异步了。异步也可以分为两种:带通知的和不带通知的。前面说的属于带通知的,有些传菜员可能干活主动性不是很够,不会主动通知你,你需要时不时关注一下状态,这就是不带通知的异步。异步 阻塞和非阻塞都是可以。非阻塞又分为两种方式:主动查询和被动接收消息,被动的效率更高,因为主动查询里绝大部分的查询是在做无用功

 

全异步I/O:

回到I/O,不管是I还是O,对外设(磁盘)的访问都可以分为请求和执行两个阶段,请求就是看外设的状态信息,执行才是真正的I/O操作

 










本文转自 小新锐 51CTO博客,原文链接:http://blog.51cto.com/13407306/2056602,如需转载请自行联系原作者
目录
相关文章
|
2月前
|
安全 前端开发 API
【Azure 应用服务】Azure Web App 服务默认支持一些 Weak TLS Ciphers Suite,是否有办法自定义修改呢?
【Azure 应用服务】Azure Web App 服务默认支持一些 Weak TLS Ciphers Suite,是否有办法自定义修改呢?
|
1月前
|
存储 API Go
使用动态模型创建web应用
【9月更文挑战第5天】动态模型描述系统中对象间的交互和状态变化,重点关注事件驱动的行为。时序图清晰展示了请求处理流程,状态图则描绘了系统状态的转换过程。
29 9
|
2月前
|
机器学习/深度学习 存储 前端开发
实战揭秘:如何借助TensorFlow.js的强大力量,轻松将高效能的机器学习模型无缝集成到Web浏览器中,从而打造智能化的前端应用并优化用户体验
【8月更文挑战第31天】将机器学习模型集成到Web应用中,可让用户在浏览器内体验智能化功能。TensorFlow.js作为在客户端浏览器中运行的库,提供了强大支持。本文通过问答形式详细介绍如何使用TensorFlow.js将机器学习模型带入Web浏览器,并通过具体示例代码展示最佳实践。首先,需在HTML文件中引入TensorFlow.js库;接着,可通过加载预训练模型如MobileNet实现图像分类;然后,编写代码处理图像识别并显示结果;此外,还介绍了如何训练自定义模型及优化模型性能的方法,包括模型量化、剪枝和压缩等。
34 1
|
2月前
|
JSON 定位技术 数据格式
web GIS神器,一行命令快捷构建精灵图服务
web GIS神器,一行命令快捷构建精灵图服务
|
2月前
|
Java 缓存 数据库连接
揭秘!Struts 2性能翻倍的秘诀:不可思议的优化技巧大公开
【8月更文挑战第31天】《Struts 2性能优化技巧》介绍了提升Struts 2 Web应用响应速度的关键策略,包括减少配置开销、优化Action处理、合理使用拦截器、精简标签库使用、改进数据访问方式、利用缓存机制以及浏览器与网络层面的优化。通过实施这些技巧,如懒加载配置、异步请求处理、高效数据库连接管理和启用GZIP压缩等,可显著提高应用性能,为用户提供更快的体验。性能优化需根据实际场景持续调整。
50 0
|
2月前
|
Java 网络架构 数据格式
Struts 2 携手 RESTful:颠覆传统,重塑Web服务新纪元的史诗级组合!
【8月更文挑战第31天】《Struts 2 与 RESTful 设计:构建现代 Web 服务》介绍如何结合 Struts 2 框架与 RESTful 设计理念,构建高效、可扩展的 Web 服务。Struts 2 的 REST 插件提供简洁的 API 和约定,使开发者能快速创建符合 REST 规范的服务接口。通过在 `struts.xml` 中配置 `<rest>` 命名空间并使用注解如 `@Action`、`@GET` 等,可轻松定义服务路径及 HTTP 方法。
38 0
|
2月前
|
前端开发 API 开发者
JSF与RESTful服务的完美邂逅:如何打造符合现代Web潮流的数据交互新体验
【8月更文挑战第31天】随着互联网技术的发展,RESTful架构风格因其实现简便与无状态特性而在Web服务构建中日益流行。本文探讨如何结合JavaServer Faces (JSF) 和 JAX-RS 构建RESTful API,展示从前端到后端分离的完整解决方案。通过定义资源类、配置 `web.xml` 文件以及使用依赖注入等步骤,演示了在JSF项目中实现RESTful服务的具体过程,为Java开发者提供了实用指南。
32 0
|
2月前
|
API UED 开发者
如何在Uno Platform中轻松实现流畅动画效果——从基础到优化,全方位打造用户友好的动态交互体验!
【8月更文挑战第31天】在开发跨平台应用时,确保用户界面流畅且具吸引力至关重要。Uno Platform 作为多端统一的开发框架,不仅支持跨系统应用开发,还能通过优化实现流畅动画,增强用户体验。本文探讨了Uno Platform中实现流畅动画的多个方面,包括动画基础、性能优化、实践技巧及问题排查,帮助开发者掌握具体优化策略,提升应用质量与用户满意度。通过合理利用故事板、减少布局复杂性、使用硬件加速等技术,结合异步方法与预设缓存技巧,开发者能够创建美观且流畅的动画效果。
57 0
|
2月前
|
Apache 开发者 Java
Apache Wicket揭秘:如何巧妙利用模型与表单机制,实现Web应用高效开发?
【8月更文挑战第31天】本文深入探讨了Apache Wicket的模型与表单处理机制。Wicket作为一个组件化的Java Web框架,提供了多种模型实现,如CompoundPropertyModel等,充当组件与数据间的桥梁。文章通过示例介绍了模型创建及使用方法,并详细讲解了表单组件、提交处理及验证机制,帮助开发者更好地理解如何利用Wicket构建高效、易维护的Web应用程序。
28 0
|
2月前
|
JSON API 数据库
探索FastAPI:不仅仅是一个Python Web框架,更是助力开发者高效构建现代化RESTful API服务的神器——从环境搭建到CRUD应用实战全面解析
【8月更文挑战第31天】FastAPI 是一个基于 Python 3.6+ 类型提示标准的现代 Web 框架,以其高性能、易用性和现代化设计而备受青睐。本文通过示例介绍了 FastAPI 的优势及其在构建高效 Web 应用中的强大功能。首先,通过安装 FastAPI 和 Uvicorn 并创建简单的“Hello, World!”应用入门;接着展示了如何处理路径参数和查询参数,并利用类型提示进行数据验证和转换。
43 0
下一篇
无影云桌面