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 踩
共 0 条评论