linux 计算程序运行时间, 及时间差

linux 计算程序运行时间, 及时间差

统计Shell脚本执行时间,帮助分析改进脚本执行

  1. 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
  1. 用 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://leoliuyt.github.io/2018/04/10/shell时间处理/

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

posted @ 2024-11-11 16:57  michaelchengjl  阅读(49)  评论(0编辑  收藏  举报