985大学小伙掉进Python GIL锁坑里,官方删除GIL锁终于有了盼头

2023年10月08日09:34:04 科技 1533

我们知道,现在python呢已经成为了一个非常普及的编程语言了,同时呢也已经成为了tiobe统计排名第一的语言,超过了java和C/C++

985大学小伙掉进Python GIL锁坑里,官方删除GIL锁终于有了盼头 - 天天要闻

TIOBE 2023年9月编程语言排行榜

因为python确实学习门槛低,非常容易上手。现在几乎所有人都会用python写一些简单的代码,实现自己的需求。但是,如果没有深入系统的学习python,也会掉进一些坑里。今天我们就来聊一聊一个有关一个身边985大学生掉进python 多线程GIL锁坑里的故事。

985大学小伙掉进Python GIL锁坑里,官方删除GIL锁终于有了盼头 - 天天要闻

最近部门来了一个刚毕业的985研究生,人很聪明动手能力也很强,在组里负责激光雷达相关的模块开发。突然有一天,小伙找到我,说代码里遇到了性能瓶颈问题,一直解决不了,很困惑。仔细了解后,知道了他在用python里的2个线程分别读取2个激光雷达的数据然后做进一步分析处理,但发现其中一个线程的读取效率特别低始终无法提高。这两个线程是在同一个进程中创建的。显然,精通python的人都知道,这里是由于Python 进程中存在GIL锁(也就是Global Interpreter Lock,即全局解释器锁)而导致的,所以我建议他改用多进程来规避这个问题,他照做之后问题得到解决。

小伙也可能是刚接触python,现学现用,忽略了系统学习,所以导致了对GIL锁缺乏了解,所以掉进了坑里。可见,学习一门编程语言,系统的学习,抓住重点,打牢基础是多么重要,所谓磨刀不误砍柴工。同时,勤学好问,也很重要,遇到问题要多向团队里的人请教,当然,前提是这个团队不内卷,和谐友好。

现在我们说回这个Pyhon中的GIL锁。学习GIL锁,起码要搞清楚5个问题:1,什么是GIL锁;2,为什么Python必须引入GIL锁?3,GIL锁什么时候释放?4,如何解决GIL锁的性能问题?5,有了GIL锁,还需要用额外的锁吗?

第一个问题:什么是GIL锁?

GIL锁和在Python代码中使用线程锁Lock并不是一个层面的概念。GIL是在实现Python解释器(CPython)时所引入的一个概念,每一个Python进程运行时都对应一个CPython解释器进程。在CPython解释器内部运行多个线程的时候,每个线程在解释器内部申请相应的全局资源,为了防止资源竞争而发生错误,对所有线程申请全局资源增加了限制-必须获得全局解释器锁GIL。每个线程想要运行首先获取这个解释器进程中唯一的GIL,因此Python进程中所有线程只能一个一个交替的执行。所以在Python程序里,就算使用多线程,运行在多核CPUS上,其实还是一个线程在工作,这是CPython的一个缺陷,其他语言没有。

第二个问题:为什么Python必须引入GIL?

Python调用的线程都是原生线程,通过C语言提供原生接口,相当于C语言的一个函数,一旦执行Python解释器就再也不能控制它,必须等它返回结果。如果启动n个线程,那么这n个线程独自执行,访问全局资源,会造成资源竞争,结果就会有问题。CPython加入GIL,就可以在同一时间只有拿到GIL锁的一个线程能够工作。虽然这n个线程都启动了,但是同一时间只能让一个线程访问全局数据,其他的几个都只能等待。

第三个问题:GIL什么时候释放?

在当前线程执行超时后会自动释放,python 3.x使用计时器(执行时间达到阈值后,当前线程释放GIL)或Python 2.x,tickets计数达到100

在当前线程执行阻塞操作时会自动释放,比如在IO操作等可能会引起阻塞的system call之前,可以暂时释放GIL,但在执行完毕后,必须重新获取GIL,因此多线程爬取比单线程性能有提升,因为遇到IO阻塞会自动释放GIL锁。

第四个问题:如何解决GIL锁的性能问题?

多线程程序在进行IO等操作时的运行速度还是要比单线程速度快,但是在运行计算密集型的程序时,需要使用CPU进行大量的计算,但由于GIL锁的性质导致程序执行中始终都是一个CPU进行计算,所以计算速度及其缓慢,运行此类的程序不推荐使用线程,有两种方式解决:

1,使用多进程的方式,避免GIL锁的约束;

2,使用其他运行速度较快的语言模块,例如C语言。

第五个问题:既然存在GIL是否意味每个线程访问全局数据就不用加Lock互斥锁了呢?

用户操作全局数据还是必须加Lock,因为GIL的释放时机我们无法控制,此时对全局数据的操作很可能并没有完成,而不像Lock那样我们用完才释放。

当然,python的GIL锁一直被开发者诟病,python官方团队也心知肚明,所以最近Python 团队已经正式接受了删除 GIL 的这个提议,并将其设置为可选模式。

深度学习三巨头之一的 Yann LeCun 发文欢呼:没有了 GIL,现在,Python 代码可以自由的执行多线程了。

985大学小伙掉进Python GIL锁坑里,官方删除GIL锁终于有了盼头 - 天天要闻

深度学习三巨头之一的 Yann LeCun 发文祝贺

CPython 核心开发者 Thomas Wouters 撰文描述了 Python 中的无 GIL 细节,并对未来发展做了展望。短期内,会将 no-GIL 构建作为一种实验性构建模式,大概会在 3.13 版本(也有可能推迟到 3.14 版本,目前官网的python版本是3.12版本)支持,比如允许用户关闭GIL锁,然后在未来某个版本将no-GIL设置为默认方式。长期来看,希望 no-GIL 成为默认方式,并删除 GIL 的所有痕迹(但不会不必要地破坏向后兼容性)。所以,python实现真正多线程的那一天也许不会太遥远了。

好,这次我们就聊到这里,谢谢大家的观看,下次再见

科技分类资讯推荐

2025年亚马逊Prime日音响特惠直播 - 天天要闻

2025年亚马逊Prime日音响特惠直播

#迎瑞午粽香纳福#快速导读Grado SR325x 耳机是市场上备受推崇的有线耳机,以其卓越音质和复古设计获得多项奖项,价格为247美元,折扣幅度显著。
互联网系数字银行抢滩港险分销,能否重塑香港保险生态? - 天天要闻

互联网系数字银行抢滩港险分销,能否重塑香港保险生态?

在低利率环境下,香港保险产品的高回报率吸引着越来越多的投资者。近期,蚂蚁银行、PAO Bank等持牌数字银行纷纷进军保险市场,分销险企的储蓄险、人寿险等高收益产品。 虽然银保合作在香港保险市场并非新鲜事物,但市场份额长期受限。部分市场观察人士期待,拥有内地互联网背景的数字银行能够凭借其技术优势和数字化运营经...
启动招募!面向全球AI创业者—— - 天天要闻

启动招募!面向全球AI创业者——

在中关村科学城北部核心区一座瞄准全球人工智能顶峰的生态地标正在崛起“中关村AI北纬社区”正式启动全球招募“中关村AI北纬社区”以“从这里,定义AI的千万种可能”为核心理念定位于建设“全球顶级人工智能生态圈”致力成为AI创业者的首选地和风向标
“婉约派”流行人声塞——浅谈达音科Vulkan2 - 天天要闻

“婉约派”流行人声塞——浅谈达音科Vulkan2

一个品牌的发展,既要考虑自身的奋斗,也要考虑历史的进程......达音科就是那个在国产便携HIFI圈子里必能史上留名的牌子,也是主流的一线品牌里最早开始卷硬件配置的那个,但是放在2025年,当年那套数单元数量再对比价格去衡量“性价比”的路线
清华大学校巴接入高德地图:可规划最优路径、查看车辆实时位置 - 天天要闻

清华大学校巴接入高德地图:可规划最优路径、查看车辆实时位置

IT之家 7 月 7 日消息,根据清华大学校园交通管理服务官方公众号“行在清华”今晚的推文,经该校学生部、保卫部、信息办及接待中心等部门协同推进,清华校园巴士线路信息正式接入高德地图导航系统。用户可通过高德地图便捷查询校园巴士路线、获取导航服务,实现校内外出行路线的无缝衔接。校方表示,升级后的导航功能支持智...
赶交期就出次品?保质量就拖进度?制造业的“平衡术” - 天天要闻

赶交期就出次品?保质量就拖进度?制造业的“平衡术”

福建一家轴承厂的老板最近很头疼。上个月接了个大客户的订单,要求30天内交付5000套精密轴承。车间主任拍胸脯保证“没问题”,结果天天加班赶工,第28天总算交了货。可没过一周,客户发来了检测报告:15%的轴承径向跳动超标,不符合装机标准。
淘宝闪购日订单超8000万:百万订单规模城市数量一周翻一倍 - 天天要闻

淘宝闪购日订单超8000万:百万订单规模城市数量一周翻一倍

新京报讯(记者秦胜南)距离淘宝闪购7月2日启动500亿补贴仅三天后,7月5日,淘宝闪购官宣订单数超过8000万,其中非餐饮订单超过1300万,淘宝闪购日活跃用户已经超过2亿。据悉,此次淘宝闪购推出500亿补贴进一步激发了城市消费热情,淘宝闪购上,日订单量突破百万的城市数量在过去一周翻了一倍。数据显示,自5月2日淘宝闪购...
罗马仕召回超49万台充电宝后续:有用户退款排到17万位 - 天天要闻

罗马仕召回超49万台充电宝后续:有用户退款排到17万位

IT之家 7 月 7 日消息,近期,充电宝召回事件成为社会关注焦点,罗马仕、安克创新等品牌相继召回多款产品,召回产品超过 120 万台,民航局也发布紧急通知,禁止旅客携带无 CCC 认证标识以及被召回型号的充电宝乘坐境内航班。