计算shell脚本的执行时间

有时候可能需要计算 shell 脚本 执行了多久, 怎么统计这个脚本 执行多长时间呢?


直接看 代码:

#!/bin/bash
start_time=`date --date='0 days ago' "+%Y-%m-%d %H:%M:%S"`

#this is your shell script 
sleep 18

##############
finish_time=`date --date='0 days ago' "+%Y-%m-%d %H:%M:%S"`

duration=$(($(($(date +%s -d "$finish_time")-$(date +%s -d "$start_time")))))

echo "this shell script execution duration: $duration"



其中

date  +%s        自UTC 时间 1970-01-01 00:00:00 以来所经过的秒数
date  -d        -d,--date=字符串       显示指定字符串所描述的时间,而非当前时间


这里把 指定的时间 ,转化为以s 单位.
date +%s -d "$start_time"  


  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
计算shell脚本执行时间,可以使用date命令或者time工具。使用date命令,可以在脚本的开始和结束位置分别获取当前时间,并计算时间差,从而得到执行时间。例如: ``` #!/bin/bash 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" ``` 另外,你还可以使用time工具来测量脚本执行时间执行`time sh your_script.sh`命令会返回三个时间数据:real、user和sys。real表示命令的总耗时,包括用户模式和内核模式下的CPU耗时、I/O等待等;user表示命令在用户模式下的CPU耗时,不包括I/O等待;sys表示命令在内核中的CPU耗时,不包括I/O等待和时间片切换耗时。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [shell脚本限制命令执行时间,设置超时时间](https://blog.csdn.net/qq_36470898/article/details/118309502)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [【ShellShell时间相关|统计Shell脚本执行时间|sleep](https://blog.csdn.net/bandaoyu/article/details/115525067)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值