AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 695438
Accepted
warvariuc
warvariuc
Asked: 2015-05-30 21:14:07 +0800 CST2015-05-30 21:14:07 +0800 CST 2015-05-30 21:14:07 +0800 CST

使用时间戳回显每个 shell 脚本命令

  • 772

set -x或set -v打印每个执行的命令。

如何在命令开始执行时打印命令?

bash
  • 3 3 个回答
  • 4652 Views

3 个回答

  • Voted
  1. ArtBIT
    2019-12-14T07:02:25+08:002019-12-14T07:02:25+08:00

    在 Bash 中,您可以使用PS4- 来为set -x跟踪输出添加前缀。

    PS4='+ $(date "+%s.%N")\011 '
    set -x
    ...
    

    \011 是水平制表符

    • 5
  2. Best Answer
    laurent
    2019-09-27T06:06:39+08:002019-09-27T06:06:39+08:00

    在 Bash 中,可以使用内置的“trap”和“DEBUG”级别来实现每个命令之后的代码执行。

    在 bash 中做:帮助陷阱或参考 bash 手册页,并查找陷阱部分

    例子:

    trap 'date' DEBUG
    

    这将在每个命令之后执行命令“date”。

    当然,您可以根据需要格式化时间戳,请参阅“日期”手册页。

    如果要删除换行符,以便时间戳出现在下一个命令的前面,您可以执行以下操作:

    trap 'echo -n $(date)' DEBUG
    

    并终止此:

    trap '' DEBUG
    

    您可以结合“set -x”/“set +x”

    • 3
  3. rubynorails
    2015-09-26T13:21:02+08:002015-09-26T13:21:02+08:00

    并不是说这是一个完美的解决方案,但我认为它基本上可以满足您的需求。只需将主脚本包装在一个函数中,并有一个单独的函数来调用时间。我确信这可以大大改进以获得确切的预期结果,但这是我想出的:

    #!/bin/bash
    
    tstamp() { date +[%T:%N]; }
    
    yourscript() {
      set -x
      echo hello
      sleep 1
      echo this
      sleep 2
      echo is
      sleep 3
      echo an
      echo example
    }
    
    yourscript | while read line; do echo -e "$(tstamp)\t$line"; done
    

    上面的脚本输出以下内容:

    + echo hello
    + sleep 1
    [16:17:33:344851100]    hello
    + echo this
    + sleep 2
    [16:17:34:352269700]    this
    + echo is
    + sleep 3
    [16:17:36:380810900]    is
    + echo an
    + echo example
    [16:17:39:392033300]    an
    [16:17:39:414361400]    example
    
    • 1

相关问题

  • Mac OS X:从 python 脚本中更改 $PATH

  • Bash 脚本:要求脚本以 root 身份运行(或使用 sudo)

  • crontab ifconfig 什么都不输出

  • 使用命令行工具按排序顺序计算重复项

  • 是否有 bash 等效于 ruby​​ 的“一些内容#{foo}”?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve