加入收藏 | 设为首页 | 会员中心 | 我要投稿 应用网_丽江站长网 (http://www.0888zz.com/)- 科技、建站、数据工具、云上网络、机器学习!
当前位置: 首页 > 运营中心 > 网站设计 > 教程 > 正文

linux中Shell并发编程案例

发布时间:2022-06-17 14:02:46 所属栏目:教程 来源:互联网
导读:Shell是系统的用户界面,提供了用户与内核进行交互操作的一种接口,它接收用户输入的命令并把它送入内核去执行了,下文就来介绍linux中Shell并发编程示例,希望能帮助到各位. 在Python中,有很多模块都可以实现并发编程,比如 threading,processing,eventlet 与
  Shell是系统的用户界面,提供了用户与内核进行交互操作的一种接口,它接收用户输入的命令并把它送入内核去执行了,下文就来介绍linux中Shell并发编程示例,希望能帮助到各位.
 
  在Python中,有很多模块都可以实现并发编程,比如 threading,processing,eventlet 与 Stackless Python 等.
 
  那么对于Shell而言,又如何实现呢?其实原理很简单,我采用的方法是.
 
  1.将需要执行的任务分批放入后台执行;
 
  2.将后台执行的命令结果汇总到指定的文件中;
 
  3.使用wait命令来等待所有任务执行结束。
 
  下面的脚本就用到了这样的并发编程方法,实现的功能是,快速(3-4秒内)对相同C网内的所有IP(255个)通过命令ping进行测试并返回结果,代码如下:
 
  vim fastping.sh
 
  #!/bin/bash
 
  # default settings
 
  subnet=$1 # C type subnet
 
  retry=2 # retry times
 
  timeout=3 # timeout seconds
 
  output=/tmp/ping.output # output file
 
  # function print_help
 
  function print_help(){
 
    echo "Examples:"
 
    echo ${0} 172.17.32
 
    echo ${0} 192.168.1 unable
 
    exit 1
 
  }
 
  # check the parameter
 
  if [ $# -lt 1 ]; then
 
    print_help
 
  fi
 
  # check the network parameter's format
 
  count=0
 
  for i in $(echo $1 |sed 's/\./ /g')
 
  do
 
    count=$((${count}+1))
 
  done
 
  if [ ${count} -ne 3 ]; then
 
    print_help
 
  fi
 
  # clean the output file
 
  > ${output}
 
  function pingable(){
 
    ping -c ${retry} -w ${timeout} -q ${subnet}.${i} &> /dev/null && echo ${i} >> ${output}
 
  }
 
  function unpingable(){
 
    ping -c ${retry} -w ${timeout} -q ${subnet}.${i} &> /dev/null || echo ${i} >> ${output}
 
  }
 
  # get the check type
 
  if [ "$2" == "unable" ]; then
 
    status="unpingable"
 
  else
 
    status="pingable"
 
  fi
 
  # ping as paraller mode and write output into file
 
  for i in {1..255}
 
  do  
 
    ${status} &
 
  done
 
  # wait for all ping processes done
 
  wait
 
  # print output with better order
 
  sum=$(wc -l ${output} |awk '{print $1}')
 
  echo "There are \"${sum}\" \"${status}\" IPs begin with \"${subnet}.\" :"
 
  cat ${output} | sort -t"." -k1,1n -k2,2n -k3,3n -k4,4n | xargs -n 20 echo " "
 
  chmod +x fastping.sh
 
  ./fastping.sh
 
  Examples:
 
  ./fastping 172.17.32
 
  ./fastping 192.168.1 unable
 
  time ./fastping.sh 192.168.1
 
  There are "142" "pingable" IPs begin with "192.168.1" :
 
    1 10 12 13 14 15 16 18 19 20 21 22 23 24 25 26 27 28 29 30
 
    31 32 33 34 35 36 37 38 40 41 42 43 44 45 46 47 48 49 50 51
 
    52 53 54 55 56 57 59 60 61 62 63 64 65 66 67 68 69 70 71 72
 
    73 74 75 76 77 78 80 81 83 84 85 86 87 88 89 90 91 92 93 94
 
    95 96 97 98 99 100 101 102 103 104 105 106 107 108 112 113 114 115 116 117  //phpfensi.com
 
    118 119 120 121 122 123 124 125 126 127 128 133 134 135 136 137 138 139 140 141
 
    142 143 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166
 
    170 254
 
  real    0m3.201s
 
  user    0m0.135s
 
  sys     0m0.495s。
 

(编辑:应用网_丽江站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读