shell进度条追踪指令执行时间的场景分析


Posted in Servers onJune 16, 2022

最近一两年,我经手了不少与shell相关的工作。在这个过程中,我越发觉得shell脚本在完成具体任务的同时,应该再给用户展示一个进度条,用以提示当前阶段还需要多少时间才能完成。

linux中的不少软件都有进度条,比如yum的软件安装过程,docker的镜像拉取过程。本想借鉴这些软件的进度条的实现方法,但其开发语言大都不是shell,我就只好作罢。随后,我在网上搜索shell进度条的实现方法,而找到的大都是用for或while循环在控制台上直接打印等号或箭头,并在循环体中用sleep命令实现一个固定的停顿,因而进度条完成的时间是固定的,而且在打印进度条时也没有实现具体任务。那种进度条是完全没有意义的。

于是,我就自己实现了一个shell进度条,测试表明实现了既定目标。可以追踪指令的执行时间。如果在预定用时之前完成,那么进度条会接到通知,然后立刻跑完剩余进度;如果指令的运行用时超出预定时间,那么进度条会在96%的地方等待指令跟上,然后再跑完剩余的4%。

本文中的进度条可以应用于大部分场景。不用修改进度条函数的任何代码,就可以直接使用。特别适合那些可预估指令执行时间的场景。对于如下载、文件复制等可以准确地计算出进度数值的情况,也可以基本满足,还可以参考本文的思路,修改进度条函数,进而显示精确的进度数值。

代码

代码如下:

#!/bin/bash
progressBarTempPath=$(mktemp)
echo "0" >"$progressBarTempPath"
progressBar () {
  local time=$1
  local interval=1
  if [[ "${time}" == *"s" ]]; then
    interval=$(echo "scale=5;${time//s/}/60"|bc)
  elif [[ "${time}" == *"m" ]]; then
    interval=${time//m/}
  else
    echo "进度条参数错误"
    return 1
  fi
  local nowNum=1
  local str=''
  local postfix=('/' '-' '\' '|')
  while [ $nowNum -le 100 ]; do
    local needEnd=`cat "$progressBarTempPath"`
    local index=$((nowNum%4))
    printf "[%-50s %-3d%% %c]\r" "$str" "$nowNum" "${postfix[$index]}"
    nowNum=$((nowNum+1))
    if [ $needEnd -eq 1 ]; then
        sleep 0.1
    else
      if  [ $nowNum -le 20 ] ; then
          sleep  $interval
      elif [  $nowNum -gt 95  ];then
          local nowNumCopy=$nowNum
          while [ $needEnd -eq 0 ]; do
              sleep $interval
              local innerIndex=$(((nowNumCopy+1)%4))
              printf "[%-50s %-3d%% %c]\r" "$str" "$nowNum" "${postfix[$innerIndex]} "
              needEnd=$(cat "$progressBarTempPath")
              nowNumCopy=$((nowNumCopy+1))
          done
      else
          sleep $(echo "scale=5;${interval}/2"|bc)
      fi
    fi
    if (($nowNum % 2 == 0)); then
      str+='='
    fi
  done
  printf "\n"
}
# 多线程调用进度条函数,参数表示预估的大概时间。参数中的s表示时间单位秒,还可以用m表分钟。
progressBar 20s &
# 调用进度条后,就是完成具体操作的代码。
echo "模拟一个24秒执行完成的任务。"
sleep 24
# 通知进度条函数完成进度
echo "1" >"$progressBarTempPath"
wait

使用说明

使用非常简单,按照以下两步操作即可。

  • 将代码中的第56、57行换成您实际需要执行的命令。最好屏蔽其运行过程中的输出。
  • 将代码中第53行的方法调用参数20s换成你预估的实际时间。

效果展示

shell进度条追踪指令执行时间的场景分析

到此这篇关于shell进度条如何追踪指令执行时间的文章就介绍到这了,更多相关shell进度条追踪指令执行时间内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!


Tags in this post...

Servers 相关文章推荐
详解Nginx 工作原理
Mar 31 Servers
nginx中proxy_pass各种用法详解
Nov 07 Servers
图文详解nginx日志切割的实现
Jan 18 Servers
Nginx中使用Lua脚本与图片的缩略图处理的实现
Mar 18 Servers
Nginx图片服务器配置之后图片访问404的问题解决
Mar 21 Servers
Z-Order加速Hudi大规模数据集方案分析
Mar 31 Servers
聊聊配置 Nginx 访问与错误日志的问题
May 25 Servers
教你如何用cmd快速登录服务器
Jun 10 Servers
Apache POI操作批量导入MySQL数据库
Jun 21 Servers
Nginx报404错误的详细解决方法
Jul 23 Servers
VMware虚拟机安装 Windows Server 2022的详细图文教程
Sep 23 Servers
Linux服务器离线安装 nginx的详细步骤
Jun 16 #Servers
利用Apache Common将java对象池化的问题
Jun 16 #Servers
Tomcat 与 maven 的安装与使用教程
V Rising 服务器搭建图文教程
安装harbor作为docker镜像仓库的问题
openEuler 搭建java开发环境的详细过程
Jun 10 #Servers
WinServer2012搭建DNS服务器的方法步骤
Jun 10 #Servers
You might like
分页显示Oracle数据库记录的类之一
2006/10/09 PHP
PHP is_dir() 判断给定文件名是否是一个目录
2010/05/10 PHP
php处理restful请求的路由类分享
2014/02/27 PHP
php观察者模式应用场景实例详解
2017/02/03 PHP
php框架CodeIgniter使用redis的方法分析
2018/04/13 PHP
ThinkPHP 3使用OSS的方法
2018/07/19 PHP
基于jQuery的ajax功能实现web service的json转化
2009/08/29 Javascript
jQuery DOM操作小结与实例
2010/01/07 Javascript
映彩衣的js随笔(js图片切换效果)
2011/07/31 Javascript
jQuery实现的登录浮动框效果代码
2015/09/26 Javascript
JS操作COOKIE实现备忘记录的方法
2016/04/01 Javascript
JS 实现Base64编码与解码实例详解
2016/11/07 Javascript
JS DOMReady事件的六种实现方法总结
2016/11/23 Javascript
javascript事件的传播基础实例讲解(35)
2017/02/14 Javascript
js实现横向拖拽导航条功能
2017/02/17 Javascript
JS实现简易刻度时钟示例代码
2017/03/11 Javascript
webpack4 + react 搭建多页面应用示例
2018/08/03 Javascript
jquery+ajax实现上传图片并显示上传进度功能【附php后台接收】
2019/06/06 jQuery
深入理解令牌认证机制(token)
2019/08/22 Javascript
wxpython中利用线程防止假死的实现方法
2014/08/11 Python
在Python中处理字符串之isdecimal()方法的使用
2015/05/20 Python
Python实现将一个大文件按段落分隔为多个小文件的简单操作方法
2017/04/17 Python
Python探索之创建二叉树
2017/10/25 Python
Python matplotlib 画图窗口显示到gui或者控制台的实例
2018/05/24 Python
python如何实现异步调用函数执行
2019/07/08 Python
python psutil模块使用方法解析
2019/08/01 Python
python脚本使用阿里云slb对恶意攻击进行封堵的实现
2021/02/04 Python
入股协议书
2014/04/14 职场文书
全国优秀教师事迹材料
2014/08/26 职场文书
镇创先争优活动总结
2014/08/28 职场文书
2014党员干部四风问题对照检查材料思想汇报
2014/09/24 职场文书
万能检讨书2000字
2014/10/17 职场文书
毕业实习证明(4篇)
2014/10/28 职场文书
幼儿教师年度个人总结
2015/02/05 职场文书
2015年关爱留守儿童工作总结
2015/05/22 职场文书
Unicode中的CJK(中日韩统一表意文字)字符小结
2021/12/06 HTML / CSS