您的位置:首页 > 运维架构 > Linux

linux 有用命令收集

2014-11-24 11:02 375 查看

列出所有文件夹

ls -F | grep "/" | awk 'gsub(/\//,"")'

多进程并发执行

http://www.hackbase.com/tech/2011-09-29/65342.html

实例一:正常情况脚本

  ———————————————————————————–

  #!/bin/bash

  for ((i=0;i<5;i++));do

  {

  sleep 1;echo 1》aa && echo ”done!”

  }

  done

  cat aa|wc -l

  rm aa

  ———————————————————————————–

  这种情况下,程序顺序执行,每个循环3s,共需15s左右。

  $ time bash test.sh

  done!

  done!

  done!

  done!

  done!

  5

  real 0m15.030s

  user 0m0.002s

  sys 0m0.003s

  实例二:“多进程”实现

  ———————————————————————————–

  #!/bin/bash

  for ((i=0;i<5;i++));do

  {

  sleep 3;echo 1》aa && echo ”done!”

  } &

  done

  wait

  cat aa|wc -l

  rm aa

  ———————————————————————————–

  这个实例实际上就在上面基础上多加了一个后台执行&符号,此时应该是5个循环任务并发执行,最后需要3s左右时间。

  $ time bash test.sh

  done!

  done!

  done!

  done!

  done!

  5

  real 0m3.011s

  user 0m0.002s

  sys 0m0.004s

  效果非常明显。

  这里需要说明一下wait的左右。wait是等待前面的后台任务全部完成才往下执行,否则程序本身是不会等待的,这样对后面依赖前面任务结果的命令来说就可能出错。例如上面wc -l的命令就报错:不存在aa这个文件。

  以上所讲的实例都是进程数目不可控制的情况,下面描述如何准确控制并发的进程数目。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: