shell多进程处理多图像

Brief

最近做一个目标检测项目的时候,一共有接近6000张高分辨率的图片,为了对图片的运算得到一个好的检测结果,采用先对图片进行图片增强的工作,但是增强的工作对一张图片处理的时间很长,一个晚上处理了130张,这么计算可能处理完整个文件夹需要16天,对于急于看到结果的我来说,是不能容忍的,因此采用shell文件进行程序并发,每一个程序处理30张,大概需要200个并行程序,希望服务器不会宕机0.0.

大体思想

通过控制文件名来控制文件数量,通过shell文件调用处理图像增强程序,同时传入需要处理的文件名称,deal.sh如下:

#!main.sh主体
#!/bin/sh
tmp_=30
for ((i=170; i<=5543; i=i+tmp_))
do
{
   python test.py $i $tmp_
}&
done
exit 1

图像增强文件文件,通过控制id处理需要处理的文件:

if  int(line) < int(sys.argv[1]) or int(line)>= (int(sys.argv[1])+int(sys.argv[2])):
            continue
运行

在这里插入图片描述

如果胆子更大一点,进一步设置每个进程处理图片的个数为15,不到2小时就处理结束了,不过CPU的占用就很高了,希望不要被管理员照顾了。
在这里插入图片描述
大概隔了一分钟。0.0
在这里插入图片描述
果然就GG了,不过学到了一句新批量杀死多进程的命令:

 ps -ef | grep python | grep -v grep | cut -c 9-15 | xargs kill -s 9

上一句是杀死 关键字是python的程序,这里的关键词指的是运行程序采用的指令

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值