广告
返回顶部
首页 > 资讯 > 精选 >怎么用Shell脚本获取进程的运行时间
  • 342
分享到

怎么用Shell脚本获取进程的运行时间

2023-06-09 19:06:26 342人浏览 安东尼
摘要

这篇文章主要介绍“怎么用shell脚本获取进程的运行时间”,在日常操作中,相信很多人在怎么用Shell脚本获取进程的运行时间问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Shell脚本获取进程的运行时间

这篇文章主要介绍“怎么用shell脚本获取进程的运行时间”,在日常操作中,相信很多人在怎么用Shell脚本获取进程的运行时间问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Shell脚本获取进程的运行时间”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

在我们的系统中,我曾写了一个脚本去定时更新一些repository,但偶尔会遇到问题,比如:git pull之时可能会卡在那里(可能由于某时刻的网络问题),它会阻碍后面的下一次更新。
所以我就在想,我今后启动这个脚本时,进行检查,如果上次运行的脚本还没结束,而且过了某个时间阀值,就把它及其子进程给kill掉。然后,我就需要写了一个可以查询某个进程已经运行了多少时间(以second为单位)的脚本。
注意:这并不是是指进程消耗的CPU时间,这里是当前时间减去进程启动时的时间,是这个时间段。

本来,ps本身也提供了选项来查询的,但是比较直观和形象(如 10:32这样的),不是用seconds为单位,并不方便在脚本中直接使用。ps中的关于进程时间的命令如下:

代码如下:


[root@jay-linux jay]# ps -p 4260 -o pid,start_time,etime,comm
  PID START     ELAPSED COMMAND
 4260 Apr18 16-08:57:25 gnome-session


其中第三列的16-08:57:25就是进程运行的时间,为:16天8小时57分25秒。

我自己根据一些/proc文件系统中的信息,查询进程运行时间脚本分享如下:

代码如下:


#!/bin/bash
function show_elapsed_time()
{
 user_hz=$(getconf CLK_TCK) #mostly it's 100 on x86/x86_64
 pid=$1
 jiffies=$(cat /proc/$pid/stat | cut -d" " -f22)
 sys_uptime=$(cat /proc/uptime | cut -d" " -f1)
 last_time=$(( ${sys_uptime%.*} - $jiffies/$user_hz ))
 echo "the process $pid lasts for $last_time seconds."
}

if [ $# -ge 1 ];then
 for pid in $@
 do
  show_elapsed_time $pid
 done
fi

while read pid
do
 show_elapsed_time $pid
done


执行过程和结果如下:

代码如下:


[root@jay-linux jay]# ./get_process_time.sh 4260
the process #4260 lasts for 1415417 seconds.

后续我再写两篇简单讲讲/proc/stat, /proc/$pid/stat, /proc/uptime吧。

到此,关于“怎么用Shell脚本获取进程的运行时间”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: 怎么用Shell脚本获取进程的运行时间

本文链接: https://www.lsjlt.com/news/257449.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么用Shell脚本获取进程的运行时间
    这篇文章主要介绍“怎么用Shell脚本获取进程的运行时间”,在日常操作中,相信很多人在怎么用Shell脚本获取进程的运行时间问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Shell脚本获取进程的运行时间...
    99+
    2023-06-09
  • Shell脚本获取进程的运行时间
    在我们的系统中,我曾写了一个脚本去定时更新一些repository,但偶尔会遇到问题,比如:git pull之时可能会卡在那里(可能由于某时刻的网络问题),它会阻碍后面的下一次更新。所以我就在想,我今后启动...
    99+
    2022-06-04
    脚本 进程 时间
  • Shell脚本中怎么获取进程ID
    今天就跟大家聊聊有关Shell脚本中怎么获取进程ID,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。在某些情况下,你也许想要知道运行中的子shell的PID。这个PID信息可以在不同的...
    99+
    2023-06-09
  • 使用shell脚本怎么实现多进程运行
    这篇文章将为大家详细讲解有关使用shell脚本怎么实现多进程运行,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。例子for ip in 192.168.56.{1...
    99+
    2023-06-09
  • Linux环境shell脚本获取时间的常用命令总结
    本篇内容介绍了“Linux环境shell脚本获取时间的常用命令总结”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 相关概念Linux的系...
    99+
    2023-06-16
  • java程序的jar包怎么利用shell脚本运行
    这篇文章将为大家详细讲解有关java程序的jar包怎么利用shell脚本运行,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。在UBuntu上部署项目的时候,我们往往通过一段shell来启动程序...
    99+
    2023-05-31
    shell java jar
  • Android应用中怎么对时间进行获取
    今天就跟大家聊聊有关Android应用中怎么对时间进行获取,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 Android 获取时间实例代码注意:h:12小时制小时数 H:2...
    99+
    2023-05-31
    android roi
  • 怎么用shell脚本进行MySQL数据库定时备份
    本篇内容介绍了“怎么用shell脚本进行MySQL数据库定时备份”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所...
    99+
    2022-10-18
  • 怎么用linux脚本判断进程是否运行
    在Linux中,可以使用脚本编写来判断进程是否正在运行。以下是一个示例脚本: #!/bin/bash # 检查进程是否在运行 pr...
    99+
    2023-10-25
    linux
  • 使用shell脚本怎么获取上个月最后一天的日期
    今天就跟大家聊聊有关使用shell脚本怎么获取上个月最后一天的日期,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。linux中用date命令来获取上个月最后一天的日期:$ d...
    99+
    2023-06-09
  • Linux怎么查看进程的启动和运行时间
    今天给大家介绍一下Linux怎么查看进程的启动和运行时间。文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。有时需要知到某进程运行的时间或是否已经运行完成,方便系统...
    99+
    2023-06-28
  • 怎么使用shell获取进程名的内存及CPU利用率
    这篇文章主要介绍“怎么使用shell获取进程名的内存及CPU利用率”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用shell获取进程名的内存及CPU利用率”文章能帮助大家解决问题。原理:1)使...
    99+
    2023-06-30
  • Java中的子文本怎么利用正则表达式进行获取
    Java中的子文本怎么利用正则表达式进行获取?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。具体方法如下:package cn.mingyuan.regexp.singlec...
    99+
    2023-05-31
    java 正则表达式 ava
  • 怎么用shell脚本实现对OGG进程过期trail文件的删除处理
    本篇内容主要讲解“怎么用shell脚本实现对OGG进程过期trail文件的删除处理”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用shell脚本实现对OGG进程过期trail文件的删除处理”...
    99+
    2023-06-04
  • Linux中显示内存和CPU使用率最高的进程是怎么样的及SHELL脚本怎么编写
    本篇文章为大家展示了Linux中显示内存和CPU使用率最高的进程是怎么样的及SHELL脚本怎么编写,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。显示CPU占用率最高的十个进程信息#  ps...
    99+
    2023-06-05
  • SQLServer 错误 17884 在最后 %d 秒内,没有一个工作线程拾取了分配给节点 %d 上的进程的新查询。 查询被阻塞或长时间运行可能导致出现此情况,并且可能会延长客户端响应时间。 请使用
    详细信息 Attribute 值 产品名称 SQL Server 事件 ID 17884 事件源 MSSQLSERVER 组件 SQLEngine 符号名称 SRV_SCHEDULER_DEADLOCK 消...
    99+
    2023-11-05
    线程 进程 工作
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作