当前位置: 首页 > news >正文

企业网站快速备案服务网络营销课程培训机构

企业网站快速备案服务,网络营销课程培训机构,关于网站建设案例,建设一个网站成本多少在许多任务处理系统中,我们需要使用异步任务队列来处理繁重的计算或长时间运行的任务,如模型训练。Celery是一个广泛使用的分布式任务队列,而在某些任务中,尤其是涉及到调用独立脚本的场景中,我们需要混合使用multipro…

在许多任务处理系统中,我们需要使用异步任务队列来处理繁重的计算或长时间运行的任务,如模型训练。Celery是一个广泛使用的分布式任务队列,而在某些任务中,尤其是涉及到调用独立脚本的场景中,我们需要混合使用multiprocessingsubprocess模块来启动和管理这些任务进程。然而,这种组合有时会带来一些挑战,如进程冲突和子进程无法正确终止的问题。

本文将讨论如何使用Celery、Multiprocessing和Subprocess来处理这些问题,并在需要时正确关闭子进程,实现完美的进程管理与切换。

问题描述

当通过celery.control.revoke来终止Celery任务时,如果任务启动了多个子进程,例如使用multiprocessingsubprocess模块,这些子进程不会被立即终止。在某些情况下,子进程会继续运行,导致任务无法彻底停止,并可能造成系统资源浪费。

解决方案

我们可以通过组合使用psutil库来实现对子进程的监控和终止,从而确保所有相关的进程都能正确关闭。以下是具体实现步骤。

安装必要的库

确保你已经安装psutil库:

pip install psutil

修改代码实现

1. Celery任务与Multiprocessing结合Subprocess

首先,我们创建一个Celery任务。当任务启动时,它会使用multiprocessing模块启动一个新的进程,该进程将执行独立的Python脚本。代码如下:

import json
import os
import psutil
import multiprocessing
import subprocess
from celery_app import celeryimport torch.multiprocessing as mpmp.set_start_method('spawn', True)def run_script(json_test_path, uid):command = f"python training.py {json_test_path}"process = subprocess.Popen(command, shell=True)print("===========================================PID:", process.pid)print("===========================================uid:", uid)process.wait()return process.pid@celery.task(bind=True)
def lora_train_task(self, json_test_demo):# 将json_test保存到临时文件中json_test_path = f"training_config_{json_test_demo['uid']}.json"json_test_path = os.path.abspath(json_test_path)with open(json_test_path, 'w') as f:json.dump(json_test_demo, f)# 使用多进程调用独立脚本p = multiprocessing.Process(target=run_script, args=(json_test_path, json_test_demo['uid']))p.start()p.join()return 0
2. 使用psutil关闭子进程

我们通过调用psutil库来监控并关闭所有相关的子进程。以下是实现终止任务和子进程的代码示例:

import psutildef terminate_process_tree(pid):try:parent = psutil.Process(pid)for child in parent.children(recursive=True):  # This will recursively find all child processeschild.terminate()parent.terminate()except psutil.NoSuchProcess:pass# 示例:终止任务时调用终止子进程函数
celery.control.revoke(args['task_id'], terminate=True, signal='SIGKILL')
if args['pid_id']:terminate_process_tree(int(args['pid_id']))

完整示例

将上述代码组合起来,我们得到完成的实现。如下所示:

import json
import os
import psutil
import multiprocessing
import subprocess
from celery_app import celery
import torch.multiprocessing as mpmp.set_start_method('spawn', True)def run_script(json_test_path, uid):command = f"python training.py {json_test_path}"process = subprocess.Popen(command, shell=True)print("===========================================PID:", process.pid)print("===========================================uid:", uid)process.wait()return process.pid@celery.task(bind=True)
def lora_train_task(self, json_test_demo):# 将json_test保存到临时文件中json_test_path = f"training_config_{json_test_demo['uid']}.json"json_test_path = os.path.abspath(json_test_path)with open(json_test_path, 'w') as f:json.dump(json_test_demo, f)# 使用多进程调用独立脚本process = multiprocessing.Process(target=run_script, args=(json_test_path, json_test_demo['uid']))process.start()process.join()return 0def terminate_process_tree(pid):try:parent = psutil.Process(pid)for child in parent.children(recursive=True):  # 递归找到所有子进程child.terminate()parent.terminate()except psutil.NoSuchProcess:pass# 示例:终止任务时调用终止子进程函数
celery.control.revoke(args['task_id'], terminate=True, signal='SIGKILL')
if args['pid_id']:terminate_process_tree(int(args['pid_id']))

结论

本文示范了如何通过混合使用Celery、Multiprocessing与Subprocess来处理复杂的任务执行场景,同时介绍了通过psutil库来正确管理和终止子进程。这种方法能够确保系统资源的合理使用,并避免出现僵尸进程问题。希望本文对你在实际项目中处理类似问题时有所帮助。

http://www.ds6.com.cn/news/27699.html

相关文章:

  • 做相册本哪个网站好用福州短视频seo
  • 山西省建设注册中心网站搜索关键词的软件
  • 为什么上传网站模板网站上没有文字和图片上海网络推广渠道
  • wordpress硬盘seo科技网
  • 消防有哪些网站合适做百度seo如何优化
  • 网站域名备案后公示市场营销方案范文5篇
  • 机械厂做的网站模板叫什么seo常见的优化技术
  • 重庆网站有哪些seo网络营销
  • 服务质量好的网站设计制作2022年传销最新消息
  • 网站开发 避免 字段变化 代码营销策略有哪些方面
  • 谁可以做开码网站中国万网登录入口
  • 台州网站建设外包廊坊seo排名优化
  • 免费设立网站查询网站流量的网址
  • 合肥做兼职网站设计疫情排行榜最新消息
  • 网站建设 人性的弱点网络营销工具与方法
  • 网站建设修饰商品网站指数查询
  • 安徽省级建设主管部门网站少儿培训
  • 网站策划书的主题有哪些电商平台网站
  • 济南网站建设找大标百度seo快速提升排名
  • 电子商务网站怎么做素材包短视频推广平台
  • 鄂尔多斯市网站建设关键词规划师工具
  • 福州网站建设策划方案淘宝代运营公司
  • 充值网站分销站怎么做百度指数关键词
  • 做网站做什么赚钱上海app开发公司
  • 仓库管理erp自学视频seo技术最新黑帽
  • 日木女人做爰视频网站百度快速排名系统查询
  • 给宝宝做辅食的网站宠物美容师宠物美容培训学校
  • 网站制作的收费标准什么叫营销
  • 搭建小网站seo优化易下拉霸屏
  • 做那个男女的视频网站提高工作效率心得体会