并发:cpu划分时间片,轮流执行每个请求任务,时间片到期后,换到下一个、

并行:在多核服务器上,每个cpu内核执行一个任务,是真正的并行

IO密集型的应用,由于请求过程中很多时间都是外部IO操作,CPU在wait状态,所以并发执行可以有效提高系统吞吐量

纯CPU密集型的应用:在单核上并发执行多个请求,不能提高系统吞吐量(由于任务来回场景切换的开销,吞吐量反而会下降);只有多核并行运算,才能有效提高吞吐量

web并发模型有:multi-process   multi-thread    multi-process+multi-thread   event I/O  coroutine

多进程优点

  • 并发模型非常简单,由操作系统调度运行稳定强壮
  • 非常容易管理(通过操作系统进行监控与系统管理)
  • 隔离性好
  • 代码兼容性极好,不必考虑线程安全问题
  • 多进程可以有效利用多核cpu,实现并行处理

多进程缺点

  • 内存消耗大户(每个独立进程都需要加载完整的应用环境,内存消耗超大)
  • cpu消耗偏高(多进程并发,需要CPU内核在多个进程间频繁切换,而进行的场景切换是非常昂贵的,需要大量的内存换页操作)
  • 很低的I/O并发处理能力
  1. 每个进程的并发能力非常有限,单台服务器启动的进程数有限,并发能力无法有效提高
  2. 只适合处理短请求,不适合处理长请求(每个请求都能在很短时间内执行完毕,因而不会造成进程长期阻塞,一但某个进程特别是IO操作阻塞,会造成进程阻塞,当大面积IO操作阻塞发生,服务器就无法响应了)

多线程优点

  • 多线程并发内存消耗比较小
  • 多线程并发CPU消耗比较小
  • 很容易创建和高效利用共享资源
  • IO并发能力很高
  • 可高效利用多核CPU,实现并行运算

多线程的缺点

  • VM的内存管理要求超高
  1. 对内存管理要求非常高,应用代码稍不注意,就会产生OOM
  2. GC的策略会影响线程并发能力和系统吞吐量,需要对GC策略和调优有很好的经验
  3. 在大内存服务器上的物理利用率问题(VM内存堆不宜过大,一般2GB为宜,过大的内存堆会造成GC效率下降,在物理内存很大的服务器上为了有效利用更多内存,需要跑多个VM,增加了复杂度)
  • 对共享资源的操作
  • 应用代码和第三方库都必须是线程安全的
  • 单进程多线程模型不方便通过操作系统管理(一旦出现线程死锁或者线程阻塞很容易导致整个VM进程挂起失去响应,隔离性很差)

event IO原理

  • 单进程单线程
  • 内部维护一个事件队列
  • 每个请求切成多个事件
  • 单进程顺序从事件队列中取出每个事件执行下去

event IO的优点

  • 惊人的IO并发处理能力
  • 极少的内存消耗(单一进程单一线程,无场景切换无需保存场景)
  • CPU消耗偏低(无进程或者线程场景切换的开销)

event IO的缺点

  • 必须使用异步编程
  • CPU密集型的运算会阻塞整个进程
  • 所有IO操作必须使用异步库
  • 只能跑在1个CPU内核上,无法有效利用多核并行运算(运行多个进程利用多核CPU)

coroutine原理

  • 在单个线程上运行多个纤程,每个纤程维护一个context
  • 纤程非常轻量级,单个线程可以轻易维护几万个纤程
  • 纤程的调度主要依赖应用程序框架
  • 纤程的切换(必须自己编程实现,一般框架实现了纤程调度)
  • 纤程本质上是基于event IO之上的高级封装,但消除了event IO原始的异步编程复杂度

coroutine的优点

  • 支持极高的IO并发,和event IO基本相当
  • 纤程的创建和切换的系统开销非常小,CPU和内存消耗都很小

coroutine的缺点

  • 纤程运行在单线程上,无法有效利用多核实现并行运算(通过启动多个进程或者多个线程来利用多核CPU)
  • CPU密集型的运算会阻塞整个进程
  • 所有IO操作必须使用异步库

原文:《《Web并发模型粗浅探讨》》

web并发模型的更多相关文章

  1. 用 Python 理解 Web 并发模型

    用 Python 理解 Web 并发模型 http://www.jianshu.com/users/1b1fde012122/latest_articles   来源:MountainKing 链接: ...

  2. 用python理解web并发模型

    最简单的并发 import socket response = 'HTTP/1.1 200 OK\r\nConnection:Close\r\nContent-Length:11\r\n\r\nHel ...

  3. Server Develop (五) Linux并发模型

    Linux并发模型 目前可以实现并发程序的方法有Apache模型(Process Per Connection,简称PPC),TPC(Thread PerConnection)模型,以及select模 ...

  4. Linux并发模型

    Linux并发模型 Linux并发模型 目前可以实现并发程序的方法有Apache模型(Process Per Connection,简称PPC),TPC(Thread PerConnection)模型 ...

  5. (转)Go语言并发模型:使用 context

    转载自:https://segmentfault.com/a/1190000006744213 context golang 简介 在 Go http包的Server中,每一个请求在都有一个对应的 g ...

  6. nginx并发模型与traffic_server并发模型简单比较

    ginx并发模型: nginx 的进程模型采用的是prefork方式,预先分配的worker子进程数量由配置文件指定,默认为1,不超过1024.master主进程创建监听套接口,fork子进程以后,由 ...

  7. Go语言 | CSP并发模型与Goroutine的基本使用

    今天是golang专题的第13篇文章,我们一起来聊聊golang当中的并发与Goroutine. 在之前的文章当中我们介绍完了golang当中常用的使用方法和规范,在接下来的文章当中和大家聊聊gola ...

  8. 课堂笔记--Strom并发模型

    Strom并发模型:     topology是如何运行的?(可与mapreduce对比)         第一层:cluster         第二层:supervisor(host.node.机 ...

  9. 构建自己的Java并发模型框架

    Java的多线程特性为构建高性能的应用提供了极大的方便,可是也带来了不少的麻烦.线程间同步.数据一致性等烦琐的问题须要细心的考虑,一不小心就会出现一些微妙的,难以调试的错误. 另外.应用逻辑和线程逻辑 ...

随机推荐

  1. 将html导出到excel或word

    本质是将html写成word或excel支持的html格式. 如何将html写成word或excel支持的格式? 只需打开计算机上任意一个word或excel文档,打开文件->另存为,选择文件类 ...

  2. Hbase写数据,存数据,读数据的详细过程

    Client写入 -> 存入MemStore,一直到MemStore满 -> Flush成一个StoreFile,直至增长到一定阈值 -> 出发Compact合并操作 -> 多 ...

  3. [Python shelve模块Error]bsddb.db.DBPageNotFoundError: (-30986, 'DB_PAGE_NOTFOUND: Requested page not found')

    在用scrapy抓数据,用shelve保存时出现了这个Error,目标是储存一串unicode字符串组成的列表,exception代码是tempbase['joke']=joke_list,测试只要j ...

  4. Taum and B'day

    //自己 def main(): t = int(raw_input()) for _ in range(t): units = 0 b, w = map(int, raw_input().strip ...

  5. Labeling Balls--poj3687

    Labeling Balls Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 12273   Accepted: 3516 D ...

  6. ExpandableListView 保证只展开一组

    expandableListView.setOnGroupExpandListener(new OnGroupExpandListener(){ @Override public void onGro ...

  7. 《Programming WPF》翻译 第9章 1.自定义控件基础

    原文:<Programming WPF>翻译 第9章 1.自定义控件基础 在写一个自定义控件之前,你需要问的第一个问题是,我真的需要一个自定义控件吗?一个写自定义控件的主要原因是为了用户界 ...

  8. (转载)Setup Factory 会话变量

    本文转自http://www.cnblogs.com/lzjsky/archive/2010/11/18/1880440.html 方便今后查询 Session variables are speci ...

  9. [置顶] Responder一点也不神秘————iOS用户响应者链完全剖析

    这篇文章想跟大家分享的主旨是iOS捕获用户事件的各种情况,以及内部封装的一些特殊事件. 我们先从UIButton谈起,UIButton大家使用的太多了,他特殊的地方就在于其内置的普通Default/高 ...

  10. 【转】Android(4.2) Sensors 学习——G-sensor,Gyroscope驱动移植

    原文网址:http://blog.csdn.net/nxh_love/article/details/11804841 本人对驱动可谓是一点不懂,鉴于公司目前高驱动的人手不够,所以我也只能两眼一抹黑硬 ...