首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用多线程加速bash脚本?

用多线程加速bash脚本?
EN

Stack Overflow用户
提问于 2016-02-02 18:44:30
回答 1查看 212关注 0票数 1

我有一个bash脚本,我把它放在一起,根据一个公共过滤器合并多个数据包捕获。我正在后台运行守护进程记录器,它根据大小滚动pcap,所以有时很难获得整个图片,因为我正在寻找的数据可能在一个pcap中,其余的数据可能在另一个pcap中。我最大的不满是无法加快这一进程。它一次只能处理一个pcap。有人对如何使用多个子进程或多个线程来加快速度有任何建议吗?

代码语言:javascript
复制
#!/bin/bash
echo '[+] example tcp dump filters:'
echo '[+] host 1.1.1.1'
echo '[+] host 1.1.1.1 dst port 80'
echo '[+] host 1.1.1.1 and host 2.2.2.2 and dst port 80'
echo 'tcpdump filter:'
read FILTER
cd /var/mycaps/
DATESTAMP=$(date +"%m-%d-%Y-%H:%M")
# make a specific folder to drop the filtered pcaps in
mkdir /var/mycaps/temp/$DATESTAMP
# iterate over all pcaps and check for an instance of your filter
for file in $(ls *.pcap); do
        tcpdump -nn -A -w temp/$DATESTAMP/$file -r $file $FILTER
        # remove empty pcaps that dont match
        if [ "`ls -l temp/$DATESTAMP/$file | awk '{print $5}'`" = "24" ]; then
                rm -f "temp/$DATESTAMP/$file"
        fi
done
echo '[+] Merging pcaps'
# cd to your pcap directory 
cd /var/mycaps/temp/${DATESTAMP}
# merge all of the pcaps into one file and remove the seperated files
mergecap *.pcap -w merged.pcap
rm -f original.*
echo "[+] Done. your files are in $(pwd)"
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-02-02 19:45:39

在后台运行循环主体,然后等待所有后台作业完成后再继续。

代码语言:javascript
复制
max_jobs=10   # For example
job_count=0
for file in *.pcap; do   # Don't iterate over the output of ls
    (tcpdump -nn -A -w temp/"$DATESTAMP"/"$file" -r "$file" $FILTER
    # remove empty pcaps that don't match. Use stat to get the file size
    if [ "$(stat -c "%s")" = 24 ]; then
            rm -f "temp/$DATESTAMP/$file"
    fi
    ) &
    job_count=$((job_count+1))
    if [ "$job_count" -gt "$max_jobs" ]; then
        wait
        job_count=0
    fi
done
wait
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35161419

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档