Python多进程编程执行任务

我的需求如下:现有一批任务,使用进程池执行,每个任务执行耗时不一样,任务并发执行期间,需要每隔一段时间监控任务执行进度

直接贴代码:

python 复制代码
import multiprocessing
import time
import random
from multiprocessing import Pool, Manager


def worker(task_id, task_status, lock):
    """任务执行函数,模拟不同耗时操作"""
    try:
        # 记录任务开始状态
        with lock:
            task_status[task_id] = "running"

        # 随机生成任务执行时间(30秒到30分钟)
        execution_time = random.uniform(1, 30)
        time.sleep(execution_time)

        # 更新任务完成状态
        with lock:
            task_status[task_id] = "completed"
        return f"Task {task_id} completed"
    except Exception as e:
        with lock:
            task_status[task_id] = f"failed: {str(e)}"
        return f"Task {task_id} failed"


def monitor_tasks(task_status, total_tasks, lock):
    """任务监控函数,每30秒输出状态"""
    while True:
        time.sleep(10)
        with lock:
            running = [k for k, v in task_status.items() if v == "running"]
            completed = [k for k, v in task_status.items() if v == "completed"]
            failed = [k for k, v in task_status.items() if v == "failed"]
            remaining = total_tasks - len(running) - len(completed)

        print(f"\n=== 系统状态监控 ===")
        print(f"正在执行的任务数: {len(running)}")
        print(f"任务详情: {running}")
        print(f"剩余任务数: {remaining}")
        print(f"已完成任务数: {len(completed)}")
        print(f"失败任务数: {len(failed)}")
        print("====================")


if __name__ == '__main__':
    # 初始化管理器
    manager = Manager()
    lock = manager.Lock()

    # 创建任务状态字典(任务ID: 状态)
    task_status = manager.dict()
    total_tasks = 100

    # 初始化所有任务状态为"pending"
    for i in range(total_tasks):
        task_status[i] = "pending"

    # 创建进程池
    with Pool(processes=16) as pool:
        # 提交所有任务
        for task_id in range(total_tasks):
            pool.apply_async(worker, args=(task_id, task_status, lock))

        # 启动监控线程
        monitor_process = multiprocessing.Process(
            target=monitor_tasks,
            args=(task_status, total_tasks, lock)
        )
        monitor_process.start()

        # 等待所有任务完成
        pool.close()
        pool.join()

        # 终止监控进程
        monitor_process.terminate()
        monitor_process.join()
相关推荐
AI数据皮皮侠19 分钟前
中国上市公司数据(2000-2023年)
大数据·人工智能·python·深度学习·机器学习
Tachyon.xue22 分钟前
Vue 3 项目集成 Element Plus + Tailwind CSS 详细教程
前端·css·vue.js
FuckPatience1 小时前
Vue 中‘$‘符号含义
前端·javascript·vue.js
Dxy12393102163 小时前
python如何通过链接下载保存视频
python·spring·音视频
东风西巷3 小时前
K-Lite Mega/FULL Codec Pack(视频解码器)
前端·电脑·音视频·软件需求
Terio_my4 小时前
Java bean 数据校验
java·开发语言·python
超级大只老咪4 小时前
何为“类”?(Java基础语法)
java·开发语言·前端
我笑了OvO5 小时前
C++类和对象(1)
java·开发语言·c++·类和对象
无咎.lsy5 小时前
裸K初级篇 - (一)蜡烛突破信号
python
weixin_436525076 小时前
Gitee - IDEA 主支 master 和分支 dev 的使用
java·ide·intellij-idea