• 企业400电话
  • 网络优化推广
  • AI电话机器人
  • 呼叫中心
  • 全 部 栏 目

    网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Linux系统下Shell多线程编程的实例
    POST TIME:2021-10-20 10:40
    #!/bin/bash
    #———————————————————————————–
    # 此例子说明了一种用wait、read命令模拟多线程的一种技巧 
    # 此技巧往往用于多主机检查,比如ssh登录、ping等等这种单进程比较慢而不耗费cpu的情况 
    # 还说明了多线程的控制 
    #———————————————————————————–
    function a_sub 
    {
     # 此处定义一个函数,作为一个线程(子进程)   
    sleep 3 # 线程的作用是sleep 3s
     }
    tmp_fifofile="/tmp/$.fifo" mkfifo $tmp_fifofile      # 新建一个fifo类型的文件  
    exec 6>$tmp_fifofile      # 将fd6指向fifo类型 
    rm $tmp_fifofile thread=15 # 此处定义线程数 
    for 
    ((i=0;i$thread;i++));do echo 
    done >6 # 事实上就是在fd6中放置了$thread个回车符
    for 
    ((i=0;i50;i++));do # 50次循环,可以理解为50个主机,或其他 
    read -u6 # 一个read -u6命令执行一次,就从fd6中减去一个回车符,然后向下执行, 
    # fd6中没有回车符的时候,就停在这了,从而实现了线程数量控制 
    { # 此处子进程开始执行,被放到后台 
    a_sub  
    { # 此处可以用来判断子进程的逻辑 
    echo "a_sub is finished" 
    || 
    { echo "sub error" 
    echo >6 # 当进程结束以后,再向fd6中加上一个回车符,即补上了read -u6减去的那个
     done wait # 等待所有的后台子进程结束 
    exec 6>- # 关闭df6 exit 0

    说明:

    此程序中的命令 

    mkfifo tmpfile

     和linux中的命令 

    mknod tmpfile p

      效?果相同。区别是mkfifo为POSIX标准,因此推荐使用它。该命令创建了一个先入先出的管道文件,并为其分配文件标志符6。管道文件是进程之间通信的一种方式,注意这一句很重要  

    exec 6>$tmp_fifofile      # 将fd6指向fifo类型

      如果没有这句,在向文件$tmp_fifofile或者6写入数据时,程序会被阻塞,直到有read读出了管道文件中的数据为止。而执行了上面这一句后就可以在程序运行期间不断向fifo类型的文件写入数据而不会阻塞,并且数据会被保存下来以供read程序读出。
    通过运行命令:

    time ./multithread.sh >/dev/null

    最终运算时间: 50/15 = 3组(每组15)+1组(5个15 组成一个组)= 4组,每组花费时间:3秒,

    则 3 * 4 = 12 秒。

    传统非多线程的代码 运算时间: 50 * 3 = 150 秒。 

    上一篇:Linux系统下 源码软件最简单的安装方法
    下一篇:liunx系统下时钟不同步会出现问题 怎么同步Linux 的系统时钟和硬件时钟?
  • 相关文章
  • 

    关于我们 | 付款方式 | 荣誉资质 | 业务提交 | 代理合作


    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信