Python3多进程踩坑记录

2021-04-04  本文已影响0人  狄仁杰666

前言

来啦老铁!

好久不见,甚是想念。

笔者已有20天未发布文章了,甚是惭愧,近期未发布文章的原因主要是自己在学习Docker相关的知识,还没到能传播知识的地步,毕竟咱不能误人子弟呀!

近期是这样安排的,近期的文章主题主要是记录工作中遇到的一些具体问题,大部分可能会与python相关。稍等时日,Docker容器相关的文章咱们也可以安排上,还请读者耐心等待!

今天咱们先来记录、学习Python3一个关于多进程的坑!

Python3多进程踩坑案例

比如我有个类,test.py,其中的“伪代码”如下:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2021/4/4 11:22 下午
# @Author : diren@xxx.com
# @Site : 
# @File : test.py
# @Software: PyCharm

from multiprocessing import Process, Queue


class Test:
    def __init__(self):
        pass

    @staticmethod
    def run_service(platform, q):
        result = XXX(platform).run()
        q.put(result)

    @classmethod
    def test(cls, platforms):
        # 采用多进程方式,并行运行各平台自动化测试
        q = Queue()
        processes = []
        for platform in platforms:
            p = Process(target=cls.run_service, args=(platform, q,))
            p.start()
            processes.append(p)
        # 等待各进程运行结束
        for process in processes:
            process.join()


if __name__ == "__main__":
    Test().test(["android", "ios"])

Python3多进程踩坑过程

先来说说之前遇到的问题,以Mac电脑为例。之前运行时,我使用的命令如下:

python3 test.py

依稀记得报错是类似:

...
may have been in progress in another thread when fork() was called”
...

当时的解决办法是添加环境变量,如命令改为:

export OBJC_DISABLE_INITIALIZE_FORK_SAFETY=YES && python3 test.py

如果仍未解决,则可以编辑~/.bash_profile文件:

vi ~/.bash_profile

文件内增加一行:

export OBJC_DISABLE_INITIALIZE_FORK_SAFETY=YES

保存完成后,命令行窗口执行:

source ~/.bash_profile

以上步骤执行完毕后,笔者确实解决了当时的问题,也顺利的运行python多进程代码段2个月左右。可现实总是喜欢在你身后开冷枪,今天突然间,我的多进程方案就没办法运行了,现象是一运行我的python多进程代码段就崩溃,Mac机器上会有一个崩溃弹框:

崩溃弹框

经调查,修改运行命令如下:

export OBJC_DISABLE_INITIALIZE_FORK_SAFETY=YES && env no_proxy='*' python3 test.py

关键点是在python3命令前添加env no_proxy='*',修改后经过实测,能够解决我的这个崩溃问题,至于是不是完完全全的正解,咱们交给时间来验证吧~

参考文献:
https://blog.yimingliu.com/2015/07/22/python-multiprocessing-code-crashes-on-os-x-under-ipython/

毒鸡汤来啦

编程学习的路上,多线程、多进程往往是其中的一个难点和区别一般编程人员的点,通过不断学习、实践、总结,咱们一定能更上一层楼,谨以此共勉!

如果本文对您有帮助,麻烦动动手指点点赞?

谢谢!

上一篇下一篇

猜你喜欢

热点阅读