我命由我不由天!如何让程序运行指定时间?

简介: 有时候,我们在使用 Linux 系统时,会出现下面这样的情景

有时候,我们在使用 Linux 系统时,会出现下面这样的情景:

  1. 一个命令或程序需要很长时间才能运行完毕,在这过程中,系统可能会假死,我们做任何操作都没用,只好重启系统;
  2. 我们仅仅想让命令或程序运行指定的时间,到了时间点就让命令/程序中止;
  3. Log 刷新很快,但我们只需要 10 秒钟的 log。

我们有两种方法来实现这样的需求。

方法1:使用 timeout 命令

timeout 命令就是为这样的需求而定制的,它可以将命令/程序的运行时间限定在你所指定的时间里。当时间到达以后,它就会发送一个信号给所运行的命令/程序,使其自动中止。timeout 命令包含在 GNU 的核心软件包里,所以它在所有 GNU/Linux 系统里都是已经预装好了,无需我们再重复安装。该命令的使用格式如下:

$ timeout <time-limit-interval> <command>

比如,执行下面的命令,程序将运行10秒后自动中止:

$ timeout 10s tail -f /var/log/pacman.log


微信图片_20220413183611.gif


在这条命令里,10s 就是指定这后面的命令只运行 10 秒。其中 s 代表 seconds ,即秒,不写的话也可以,默认单位是秒。除此之外,还有下列单位可用:

  • m - 分钟
  • h - 小时
  • d - 天

如果仅仅是运行 tail -f /var/log/pacman.log 这条命令的话,那命令将一直运行,直到你按 ctrl+ctimeout 命令默认是到达指定时间后,发送 SIGKILL 信号。但是,其实你可以指定它所发送的信号,使用 -k 命令即可。

$ timeout -k 20 10 tail -f /var/log/pacman.log

在以上命令, 10 秒之后将发送代号为 20 的信号,即 SIGTSTP 命令。所有支持的信号可使用以下命令查询:

$ kill -l

timeout 命令在进行硬件调试时特别有用。比如,下面这条命令将显示 10 秒内核信息:

$ timeout 10 dmesg -w

需要了解更多信息,可以使用 man timeout 命令来查看。

方法2:使用 timelimit 命令

timelimit 功能与 timeout 命令类似,但它有更多选项。你不仅可以指定时间终止后所发送的信号,也可以指定信号发送次数。所以,timelimit 命令更灵活。除此之外,它会先发送警告信号,然后在超时后发送你所指定的信号。timelimit 命令没有预先安装,对于 Debian 系统的系统,你可以使用以下命令安装:

$ sudo apt-get install timelimit

其它操作系统可以使用所对应的安装方式,或者使用源码安装。安装成功之后,上述例程用 timelimit 命令来实现的话,是这样操作:

$ timelimit -t10 tail -f /var/log/pacman.log

如果你在运行时不带任何参数,那么它的默认值如下:warntime=3600 seconds, warnsig=15, killtime=120, killsig=9需要了解更多信息,可以使用 man timelimit 命令来查看。

目录
相关文章
|
10月前
|
缓存 算法 Java
透彻理解JVM中垃圾回收GC生产参数,停顿时间+执行效率相关参数
停顿时间相关参数 部分垃圾回收器实现了GC执行时应用最大停顿时间的功能,所以提供参数用于应用控制停顿时间。另外,GC为了满足停顿时间,会设计和实现一些动态算法来调整堆空间,从而满足停顿时间这个目标。本节介绍相关参数。 该参数表示GC的最大的停顿时间。不同GC对于该参数的行为不一致,具体来说: 1)若Parallel GC中GC执行的时间超过该值,将导致调整新生代和老生代的大小(参数UseAdaptiveSizePolicy设置为true)。参数的默认值为4294 967 295,大约为50天(所以通常不会触发这个调整策略)。 2)若G1中GC执行的时间超过该值,将导致调整新生代的大小和
|
11月前
|
编译器 程序员 C语言
编译时间和运行态时间交换的优缺点
编译时间和运行态时间交换的优缺点
69 0
|
存储 监控 算法
|
存储 程序员 编译器
Win知识 - 程序是怎样跑起来的——程序加载时会生成栈和堆
Win知识 - 程序是怎样跑起来的——程序加载时会生成栈和堆
100 0
Win知识 - 程序是怎样跑起来的——程序加载时会生成栈和堆
|
Java 数据库
在程序里面,时间真的发生了345秒的倒流。(下)
在程序里面,时间真的发生了345秒的倒流。(下)
106 0
在程序里面,时间真的发生了345秒的倒流。(下)
|
Java 数据库
在程序里面,时间真的发生了343秒的倒流。(上)
在程序里面,时间真的发生了343秒的倒流。(上)
166 0
在程序里面,时间真的发生了343秒的倒流。(上)
|
Java
在程序里面,时间真的发生了344秒的倒流。(中)
在程序里面,时间真的发生了344秒的倒流。(中)
101 0
在程序里面,时间真的发生了344秒的倒流。(中)
|
存储 SQL 监控
由一次不断GC并耗费过长的时间所想到的工具 - jvmkill与jvmquake
由一次不断GC并耗费过长的时间所想到的工具 - jvmkill与jvmquake