• Ukieweb

    佳的博客

    曾梦想仗剑天涯,后来工作忙没去。

linux shell: date 命令获取时间间隔到毫秒、纳秒级别

date 命令:

  • %s:表示当前时间的秒数

  • %N表示当前时间的纳秒部分,即1秒以下的那部分,

那么通过%s%N结合使用,我们就可以拿到纳秒级别的数据了。如下:

[root@dk99 ~]# date +%s.%N
1560219799.303042054

如果我们要测试一个程序运行时间,需要精确到 ms 毫秒 级别的话,可以用以下脚本:

#! /bin/bash
#filename: test.sh
# arg1=start, arg2=end, format: %s.%N
function getTiming() {
  start=$1
  end=$2
  start_s=$(echo $start | cut -d '.' -f 1)
  start_ns=$(echo $start | cut -d '.' -f 2)
  end_s=$(echo $end | cut -d '.' -f 1)
  end_ns=$(echo $end | cut -d '.' -f 2)
  time=$(( ( $end_s - $start_s ) * 1000 + ( $end_ns / 1000000 - $start_ns / 1000000 ) ))
  echo "$time ms"
}
echo "开始测试命令"
start=$(date +%s.%N)
ls >& /dev/null    # 要测试的命令
end=$(date +%s.%N)
getTiming $start $end

运行这个脚本:

[root@dk88 ~]# sh hahao.sh 
开始测试命令
3 ms
[root@dk88 ~]# sh hahao.sh 
开始测试命令
2 ms


0
0
下一篇:在 CentOS 7 上为Docker Swarm配置Linux防火墙

0 条评论

老佳啊

85后,大专学历,中原人士,家里没矿。

由于年轻时长的比较帅气,导致在别人眼里,我一直不谈恋爱的原因是清高,实则是自己的小自卑。最大的人生目标就是找一个相知相爱相容的人,共度余生。

和人相处时如果能感受到真诚,会非常注重彼此的关系,对别人没有什么心机,即使有利益冲突,一般也会以和为贵,因为在这个世界上,物质的东西,从来不会吸引到我。

特别迷恋那些大山大水,如果现在还能隐居,可能早就去了。对那些宏伟的有底蕴的人文景观比较不感冒。

从事于IT行业,却一直对厨房念念不忘,由于身材魁梧,总觉得自己上辈子是个将军,可惜这辈子没当兵,也不会打架。