python多线程和多进程——python并行编程实验

工作中经常涉及到加速程序的运行,除了代码逻辑的优化,算法的优化之外,还经常使用的一招就是并发编程。至于python的并型编程这一块。说到并行编程,我们不得不谈线程和进程这两个概念:

  • 进程:对于操作系统来说,一个任务就是一个进程(Process),熟悉linux的朋友敲命令ps -aux 就可以看到本机正在启动的任务——进程 。
  • 线程:在一个进程内部(一个任务),要同时干多件事,就需要同时运行多个“子任务”,我们把进程内的这些“子任务”称为线程(Thread)。

这里要注意的是每个进程至少要干一个任务,每个进程至少有一个线程

正常的程序都是顺序执行,你完成干完一件事后再接着干下一件事。这样就会出现一个问题,无法同时干多件事。而并行编程就是希望程序能够同时干多件事情,起到程序加速运行的效果

并行编程的三种模式

  • 1.多进程: 开启多个进程,每个进程中都有一个线程,并行去执行多个任务。
  • 2.多线程 :只开启一个进程,在进程中采取多线程编程模式,真正的多线程是将任务分发到不同的CPU,充分利用多核CPU。
  • 3.多进程加多线程:这个就是上面两种的组合,开启多个进程,每个进程中都采用多个进程去合力完成多个任务。

这里我们就来好好解释一下,python的GIL机制:python的GIL本质是一把互斥锁,保证同一时间只有一条线程访问解释器级别的数据,这样就避免了数据竞争带来的混乱,但是这个机制使得原本希望多线程带来的并行执行,变成了串行执行

如果是I/O密集型操作,比如访问web服务,访问数据库等时,由于这些操作不涉及到CPU的运算,所以此时多线程就能够发挥优势,多线程可以同时进行多个I/O操作,加速程序运行。

CPU密集型操作,要频繁使用CPU计算的场景,python中的多线程则几乎完全变成了串行,加之还要在不同线程中间切换,有时效果还不如顺序执行。此时就需要使用多进程来加速程序运行。

实验部分

导入multiprocessing.dummy ——python中多线程模块,threading拥有同样功能;multiprocessing——python中多进程模块。

import requests
import time
from multiprocessing.dummy import Pool as ThreadPool
from multiprocessing import Pool

tpool = ThreadPool()
ppool = Pool()

I/O密集型任务测试

在I/O密集型任务上分布测试 顺序执行,多线程,多进程的速度如何:

urls = ["https://www.baidu.com/"]*100

time_1 = time.time()
for i in urls:
    requests.get("https://www.baidu.com/")
time_2 = time.time()
print("I/O密集型:for 循环使用时间",time_2-time_1)


time_3 = time.time()
tpool.map(requests.get,urls)
time_4 = time.time()
print("I/O密集型:多线程使用时间",time_4-time_3)


time_5 = time.time()
ppool.map(requests.get,urls)
time_6 = time.time()
print("I/O密集型:多进程使用时间",time_6-time_5)

结果如下:
I/O密集型:for 循环使用时间 14.102440595626831
I/O密集型:多线程使用时间 2.5032284259796143
I/O密集型:多进程使用时间 2.267827272415161

多线程和多进程确实比顺序执行快了将近6倍,而多进程和多线程的速度差不多。

CPU(计算)密集型任务测试

在CPU(计算)密集型任务上分布测试 顺序执行,多线程,多进程的速度如何:

data = [10000]*10
def get_jiecheng(num):
    res = 1
    for i in range(num):
        res *= (i+1)
        
time_7 = time.time()
for i in data:
    get_jiecheng(i)
time_8 = time.time()
print("计算密集型:for 循环使用时间",time_8-time_7)


time_9 = time.time()
tpool.map(get_jiecheng,data)
time_10 = time.time()
print("计算密集型:多线程使用时间",time_10 - time_9)


time_11 = time.time()
ppool.map(get_jiecheng,data)
time_12 = time.time()
print("计算密集型:多进程使用时间",time_12-time_11)

time_13 = time.time()
ppool.map_async(get_jiecheng,data)
time_14 = time.time()
print("计算密集型:多进程异步使用时间",time_14-time_13)

计算密集型:for 循环使用时间 0.5359704494476318
计算密集型:多线程使用时间 0.5580940246582031
计算密集型:多进程使用时间 0.10313701629638672
计算密集型:多进程异步使用时间 0.00018835067749023438

此时多线程反而变成慢了,多进程比多线程和顺序执行快了大概5倍左右,同时,异步的多进程最快,加速5000多倍。但是异步的缺点也显而易见,就是无法实现进程之间的通信。

python的多进程在linux服务器上存在在一个内存复制机制——子进程会复制父进程的状态(内存空间数据等),所以如果主进程耗的资源较多时,就会造成大量的不必要的内存复制,从而导致内存爆掉。

总结

综上python 多进程和多线程总结如下:

  • 多线程的缺点:CPU密集型计算速度变慢。
  • 多线程的优点:I/O密集型计算加速效果明显,不是特别消耗CPU和内存资源。
  • 多进程的缺点:特别消耗耗CPU和内存资源
  • 多进程的优点:I/O密集型和CPU密集型计算加速效果明显。

所以笔者建议以后碰到I/O密集型计算建议使用 python多线程,而CPU密集型计算建议使用python多进程。

参考

https://www.liaoxuefeng.com/wiki/897692888725344/923056118147584
https://blog.csdn.net/qq_33733970/article/details/77988642

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 162,306评论 4 370
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,657评论 2 307
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 111,928评论 0 254
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,688评论 0 220
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 53,105评论 3 295
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 41,024评论 1 225
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,159评论 2 318
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,937评论 0 212
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,689评论 1 250
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,851评论 2 254
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,325评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,651评论 3 263
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,364评论 3 244
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,192评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,985评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,154评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,955评论 2 279

推荐阅读更多精彩内容