shell 实现多进程并发示例–控制并发数量的while循环及for循环
while 循环
适合并发目标没有规律,比如被循环的目标 IP 不是连续的,可以把它们写在一个文件中,之后读取这个文件,下面有示例。
代码
multiprocess-while.sh
#!/usr/bin/env bash
# 这里定义变量
# 这里定义需要实现具体功能的函数
# 就是你想干啥,就在这里定义
task (){
echo $line |awk '{print $1}'
# 这个只是为了模拟每个子进程任务执行时所耗费的时间
# 以便在调试的过程中,能看出并发效果
# 生产的时候可以删除或者注释掉
sleep 2
}
# 下面是定义每次并发的线程数,你可以自己修改这个数,
# 不可以太多,太多,机器就挂了
num=$1
# 下面这段不用动
mkfifo testfifo # 创建命名管道文件
exec 7<>testfifo # 给命名管道起个文件描述符
rm -rf testfifo # 删除这个命名管道文件,但是管道依然存在,可以使用文件描述符 7 进行使用。