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实现真正多线程的那一天也许不会太遥远了。

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

科技分类资讯推荐

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

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

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 认证标识以及被召回型号的充电宝乘坐境内航班。
今天凌晨!罗马仕宣布:停工停产 - 天天要闻

今天凌晨!罗马仕宣布:停工停产

据界面新闻消息,记者从罗马仕员工处获悉,7月6日凌晨1点多,罗马仕正式发布停工停产放假通知。通知称,随着市场环境的不断变化和公司业务的发展需要,经公司股东会研究决定,近段时间公司停工停产。停工时间为自2025年7月7日起持续6个月。除召回相
解秘“高标准打造数字龙华”重要战略进展 - 天天要闻

解秘“高标准打造数字龙华”重要战略进展

南都讯 记者张小玲 实习生何昕怡 “全域推进数字化发展,高标准打造数字龙华”作为龙华区今年政府工作报告重要战略进展如何?龙华区科创局近日透露,龙华区通过构建人工智能产业生态,累计已推动近百款AI产品进入应用场所。今年以来,已储备第四范式、镜识机器人、上海哇嘶嗒科技、智动未来、诺亦腾科技等多家具备核心技术...
UPS电源—UPS电源能用在这些地方 - 天天要闻

UPS电源—UPS电源能用在这些地方

UPS不间断电源作为一种能够提供持续、稳定电力的设备,其应用场景广泛,以下是UPS不间断电源在不同场景下的应用:一、数据中心与服务器房在数据中心和服务器房中,UPS不间断电源是不可或缺的守护神。
差价6万多,小鹏G7为什么还要对比特斯拉Model Y? - 天天要闻

差价6万多,小鹏G7为什么还要对比特斯拉Model Y?

小鹏G7正式上市了,售价19.58-22.58万元,相比预售时公布的23.58万元要低了不少。当小米YU7在6月底以25.35万元起的价格狂揽3分钟20万台大定订单时,恐怕很多人都会想,小鹏G7相比特斯拉Model Y和小米YU7才便宜两三万,这怎么打得过别人