linux 计算程序运行时间, 及时间差
统计Shell脚本执行时间,帮助分析改进脚本执行
-
linux shell 计算时间差值
#!/bin/bash
# 计算时间差
date1=$(date +"%Y-%m-%d %H:%M:%S")
echo "时间1: $date1"
echo "延时10s"
sleep 10
date2=$(date +"%Y-%m-%d %H:%M:%S")
echo "时间2: $date2"
sys_date1=$(date -d "$date1" +%s)
echo "时间1转化为系统时间:$sys_date1"
sys_date2=$(date -d "$date2" +%s)
echo "时间2转化为系统时间: $sys_date2"
time=`expr $sys_date2 - $sys_date1`
echo "时间1和时间2的差值: $time"
------------------------------------------
startTime=`date +%Y%m%d-%H:%M:%S`
startTime_s=`date +%s`
endTime=`date +%Y%m%d-%H:%M:%S`
endTime_s=`date +%s`
sumTime=$[ $endTime_s - $startTime_s ]
echo "$startTime ---> $endTime" "Total:$sumTime seconds"
./test.sh
时间1: 2019-11-21 16:41:24
延时10s
时间2: 2019-11-21 16:41:34
时间1转化为系统时间:1574325684
时间2转化为系统时间: 1574325694
时间1和时间2的差值: 10
-
用 time 工具
time sh xxx.sh
# 会返回3个时间数据
# real 该命令的总耗时, 包括user和sys及io等待, 时间片切换等待等等
# user 该命令在用户模式下的CPU耗时,也就是内核外的CPU耗时,不含IO等待这些时间
# sys 该命令在内核中的CPU耗时,不含IO,时间片切换耗时.
Linux date命令可以用来显示或设定系统的日期与时间,在显示方面,使用者可以设定欲显示的格式,格式设定为一个加号后接数个标记,其中可用的标记列表如下:
时间方面:
- % : 印出 %
- %n : 下一行
- %t : 跳格
- %H : 小时(00..23)
- %I : 小时(01..12)
- %k : 小时(0..23)
- %l : 小时(1..12)
- %M : 分钟(00..59)
- %p : 显示本地 AM 或 PM
- %r : 直接显示时间 (12 小时制,格式为 hh:mm:ss [AP]M)
- %s : 从 1970 年 1 月 1 日 00:00:00 UTC 到目前为止的秒数
- %S : 秒(00..61)
- %T : 直接显示时间 (24 小时制)
- %X : 相当于 %H:%M:%S
- %Z : 显示时区
日期方面:
- %a : 星期几 (Sun..Sat)
- %A : 星期几 (Sunday..Saturday)
- %b : 月份 (Jan..Dec)
- %B : 月份 (January..December)
- %c : 直接显示日期与时间
- %d : 日 (01..31)
- %D : 直接显示日期 (mm/dd/yy)
- %h : 同 %b
- %j : 一年中的第几天 (001..366)
- %m : 月份 (01..12)
- %U : 一年中的第几周 (00..53) (以 Sunday 为一周的第一天的情形)
- %w : 一周中的第几天 (0..6)
- %W : 一年中的第几周 (00..53) (以 Monday 为一周的第一天的情形)
- %x : 直接显示日期 (mm/dd/yy)
- %y : 年份的最后两位数字 (00.99)
- %Y : 完整年份 (0000..9999)
若是不以加号作为开头,则表示要设定时间,而时间格式为 MMDDhhmm[[CC]YY][.ss],其中 MM 为月份,DD 为日,hh 为小时,mm 为分钟,CC 为年份前两位数字,YY 为年份后两位数字,ss 为秒数。
当您以 root 身分更改了系统时间之后,请记得以 clock -w 来将系统时间写入 CMOS 中,这样下次重新开机时系统时间才会持续抱持最新的正确值。
https://cloud.tencent.com/developer/article/1441802
https://weiliang-ms.github.io/wl-awesome/1.Linux基础/1.1常用shell/02计算shell运行时间.html
https://www.cnblogs.com/bandaoyu/p/16752279.html
https://cloud.tencent.com/developer/article/1455278