0

0

Python 多进程退出与清理机制

舞夢輝影

舞夢輝影

发布时间:2026-02-22 21:57:33

|

298人浏览过

|

来源于php中文网

原创

atexit注册函数仅在当前进程正常退出时触发,不跨进程生效;子进程崩溃或被信号终止时,其atexit回调不会执行,必须用try/except/finally或signal.signal显式处理清理。

python 多进程退出与清理机制

子进程崩溃时主进程不退出?atexit 失效的真相

Python 的 atexit 注册函数只在当前进程正常退出(如 sys.exit()、脚本自然结束)时触发,**不会跨进程生效**。多进程场景下,子进程崩溃或被 os.kill() 终止,其内部注册的 atexit 回调根本不会执行。

常见错误现象:你在子进程中用 atexit.register(cleanup_tmp),但子进程被 signal.SIGTERM 杀掉后,临时文件还在;或者子进程因未捕获异常直接退出,atexit 彻底静默。

  • 真正可靠的清理必须放在子进程自己的异常处理链路里,比如 try/except/finally 块中
  • 若依赖信号退出,需显式注册 signal.signal(signal.SIGTERM, handler) 并在 handler 里调用清理逻辑
  • multiprocessing.Processterminate() 方法不给子进程任何执行清理的机会,它等价于 os.kill(..., SIGKILL)

multiprocessing.Pool 关闭后资源没释放?别只调 close()

Pool.close() 只是禁止提交新任务,已提交任务仍在运行;Pool.terminate() 强制杀掉所有工作进程,但两者都不等待子进程真正退出——这意味着主进程可能提前结束,而子进程残留的文件句柄、锁、共享内存段还卡在系统里。

使用场景:跑完一批 CPU 密集任务后要立刻释放 GPU 显存、删掉临时 mmap 文件、关闭数据库连接池。

立即学习Python免费学习笔记(深入)”;

EnablePPA中小学绩效考核系统2.0
EnablePPA中小学绩效考核系统2.0

无论从何种情形出发,在目前校长负责制的制度安排下,中小学校长作为学校的领导者、管理者和教育者,其管理水平对于学校发展的重要性都是不言而喻的。从这个角度看,建立科学的校长绩效评价体系以及拥有相对应的评估手段和工具,有利于教育行政机关针对校长的管理实践全过程及其结果进行测定与衡量,做出价值判断和评估,从而有利于强化学校教学管理,提升教学质量,并衍生带来校长转变管理观念,提升自身综合管理素质。

下载
  • 必须配对使用:pool.close(); pool.join() 才能确保所有子进程结束
  • pool.join() 会阻塞主进程,直到所有工作进程退出;若子进程卡死,主进程就永远 hang 住
  • 更安全的做法是加超时:pool.join(timeout=30),超时后手动 pool.terminate() 再重试
  • 注意:join() 前必须先 close()terminate(),否则抛 ValueError

子进程里用 threading.Lock 会死锁?共享对象的陷阱

多进程不是多线程,threading.Lockthreading.Event 等线程同步原语**不能跨进程共享**。把它们作为参数传给 Process 或放进 Manager,实际发生的是 pickle + 反序列化,得到的是新对象副本,完全无法协调多个进程。

常见错误现象:多个子进程同时写一个日志文件,以为加了 threading.Lock 就安全,结果日志还是乱序或损坏;或者用 Manager().dict() 存状态,却用线程锁去保护它,纯属无效操作。

  • 进程间同步必须用 multiprocessing.Lockmultiprocessing.Semaphoremultiprocessing.Event
  • Manager() 返回的对象(如 dictlist)本身已做进程安全封装,一般不需要额外加锁
  • 如果要用文件做协调,优先考虑 os.open(..., os.O_EXCL | os.O_CREAT) 这类原子操作,而不是靠锁

Windows 下子进程继承句柄导致主进程无法退出

Windows 默认将主进程的打开句柄(文件、socket、pipe)**继承给子进程**。如果子进程没显式关闭这些句柄,主进程调用 process.join()pool.close() 后,仍可能因句柄被占用而无法彻底退出——尤其常见于日志文件、数据库连接、子进程启动的 subprocess。

性能影响:句柄泄漏会拖慢进程销毁速度,严重时触发系统句柄数限制,后续 Process 创建失败,报错 OSError: [WinError 87] The parameter is incorrect

  • 启动子进程时加 close_fds=True(Python 3.7+ 默认为 True,但旧版本或某些封装库可能关掉)
  • 子进程入口函数开头加 import multiprocessing; multiprocessing.set_start_method('spawn', force=True),避免 fork 类行为残留
  • 检查是否用了 subprocess.Popen(..., stdout=xxx) 把主进程的 sys.stdout 传下去——这会让子进程持有一个指向主进程 stdout 的句柄
事情说清了就结束。最麻烦的永远不是“怎么写”,而是“哪个清理动作该在哪一层做”——主进程、子进程、甚至子进程里的 subprocess,各自的生命周期和资源归属得掰扯清楚,不然总有一处漏网。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

715

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

370

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

26

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

25

2026.01.21

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

99

2026.02.06

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1231

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1151

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

823

2023.08.01

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1030

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号