linux 计算程序运行时间, 及时间差
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://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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY