zoukankan      html  css  js  c++  java
  • 我命由我不由天!如何只让程序运行指定时间?

    有时候,我们在使用 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
    

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

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

    如果仅仅是运行 tail -f /var/log/pacman.log 这条命令的话,那命令将一直运行,直到你按 ctrl+c

    timeout 命令默认是到达指定时间后,发送 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 命令来查看。

    看完的都是真爱,点个赞再走呗?您的「三连」就是良许持续创作的最大动力!

    1. 关注原创公众号「良许Linux」,第一时间获取最新Linux干货!
    2. 公众号后台回复【资料】【面试】【简历】获取精选一线大厂面试、自我提升、简历等资料。
    3. 关注我的博客:lxlinux.net
  • 相关阅读:
    Selenium2+python自动化71-多个浏览器之间的切换【转载】
    Selenium2+python自动化70-unittest之跳过用例(skip)【转载】
    Selenium2+python自动化69-PhantomJS使用【转载】
    页面跳转(页面从哪儿来回哪儿去)
    请求报错总结
    datetimepicker.js 使用笔记
    兼容性记录
    submit()提交表单时,显示警示框
    将时间戳转换为时间
    css精简命名
  • 原文地址:https://www.cnblogs.com/yychuyu/p/12626798.html
Copyright © 2011-2022 走看看