• shell 多线程


    1. 线程数量不可控

    #!/usr/bin/bash
    
    function  do_work() {
        echo "线程 $1 运行中..."
        sleep 1m
    }
    
    echo "线程数量不可控演示..."
    for i in {1..100}; do {
        do_work $i
    }&
    done; wait  #等待结束
    echo "用时 $SECONDS 秒"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    2. 线程数量可控

    方案1:(管道FIFO+文件描述符)

    #!/usr/bin/bash
    
    function  do_work() {
        echo "线程 $1 运行中..."
        sleep 3s
    }
    
    # 1. #以‘>读写<’方式指向新建的管道fifo,新建好后可以删除
    f="/tmp/$$.fifo" # $$表示进程号
    mkfifo $f; exec 5<>$f; rm $f
    
    # 2.可控的干活    in > [====fifo====] >out
    thread=5; jobs=20   # 线程数,任务数
    echo "数量可控的多线程运行, 每次${thread}个线程..."
    for i in $(seq 1 1 $thread); do echo >&5; done  #随便echo个字符在fd中
    for i in $(seq 1 1 $jobs);   do
        read -u5 #每次从fd中减去一个字符
        {
            do_work $i
            echo >&5  #随便echo个字符在fd中
        }&
    done; wait
    
    exec 5>&-  #关闭fd读
    exec 5<&-  #关闭fd写
    
    echo "用时 $SECONDS 秒"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27

    方案2:根据进程实时目录: /proc/pid

    #!/usr/bin/bash
    
    function  do_work() {
        echo "线程 $1 运行中..."
        sleep 3s
    }
    
    function check_done {
        old=$que; que=""; n=0
        for pid in $old; do
            [[ ! -d /proc/$pid ]] && continue
            ((n++)); que+="$pid "
        done
    }
    
    thread=5; jobs=20 # 线程数,任务数
    echo "数量可控的多线程运行, 每次${thread}个线程..."
    for i in $(seq 1 1 $jobs); do
        do_work $i&
        que+="$! " #PID
        ((n++))
        while [[ $n -ge $thread ]]; do
            check_done
        done
    done
    wait
    
    echo "用时 $SECONDS 秒"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
  • 相关阅读:
    【产品设计】有了创意,如何从零开始搭建一套产品模型
    开发从0 到1获取代码,提交,推送
    跨境商城源码有哪些独特的功能和优势
    SystemVerilog Assertions应用指南 Chapter 11.5SVA检验器的时序窗口
    【限定词习题】复习
    链表去重Java
    ggplot2颜色设置总结
    Leetcode 503.下一个更大元素Ⅱ
    JCL 和 SLF4J
    HTML嵌入JS代码的三种方式
  • 原文地址:https://blog.csdn.net/weixin_41799721/article/details/134027031