python多线程框架_基于python和bash的多线程任务框架 不要让cpu闲着了
[Bash shell] 純文本查看 復(fù)制代碼#! /bin/bash
##########################################################################################################
#part1:defile your job(第一部分,定義單核任務(wù),需要根據(jù)你的實用任務(wù)改動)
date >>time
Nproc=40 #prcocess used here (要用的線程數(shù))
ls *ligand.mol2 >list #list of jobs (所有的任務(wù)放到一個list里面)
Njob=$(echo $(cat list|wc -l)+1|bc) #total jobs+1 (統(tǒng)計總?cè)蝿?wù)數(shù)目)
function jobrun #define your job (定義一個函數(shù)任務(wù))
{
j=$(cat list|sed -n "$1"p|cut -c 1-4) #$1 is a parameter for jobid ($1作為函數(shù)輸入 即任務(wù)號 這里首先要找到任務(wù)號對應(yīng)的分子)
prepare_dpf42.py -l $j"_ligand.pdbqt" -r $j"_receptor.pdbqt" -o tmp2 #(為了簡單期間這里沒有寫如何計算格子 如何計算格點文件 這里是從準備dpf文件開始)
autodock4 -p $j.dpf -l $j.dlg #(對接)
}
##############################################################################################################
#part2:mutiple process framwork (第二部分,多線程框架,可以不用懂不用改動)
PID=() #PID is an array to store the pid of your job (PID 用于儲存每個線程的pid)
for ((i=1;i
do
for ((Ijob=0; Ijob
do
if [[ $i -ge $Njob ]]; #(如果任務(wù)都完成了就退出循環(huán))
then
break;
fi
if [[ ! "${PID[Ijob]}" ]] || ! kill -0 ${PID[Ijob]} 2> /dev/null; then #(如果線程沒有被占用)
echo start $i with $Ijob
jobrun $i $Ijob& #(用Ijob線程執(zhí)行任務(wù)i)
PID[Ijob]=$! #(任務(wù)完成 釋放線程Ijob)
i=$((i+1))
fi
done
##########################################################################################
wait #(等所有線程都空閑下來)
done
echo job finished!
date >>time
總結(jié)
以上是生活随笔為你收集整理的python多线程框架_基于python和bash的多线程任务框架 不要让cpu闲着了的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python打印九九加法表_Python
- 下一篇: python三元表达式求值_python