【问题标题】:how can i capture every "set -x" log to syslog?如何将每个“set -x”日志捕获到 syslog?
【发布时间】:2012-08-23 03:05:05
【问题描述】:

情况是这样的

我有一个 shell 脚本,它运行一些具有不同参数和选项的复杂命令。

这些参数和选项是由第三方应用程序传递的,所以我可能不知道每次向 shell 脚本传递的参数和选项是什么

所以为了知道这一点,我在 shell 脚本的开头使用 set -x 来查看该命令到底在运行什么。我想使用记录器将那些调试器消息从 set -x 移动到 syslog。

我用trap来做

trap "logger $(BASH_COMMAND)" DEBUG

但是 syslog 的输出并没有它正在运行的确切命令,而是那样......

apple=1
orange=2
command $apple $orange

..................

但我希望日志的输出应该是

command 1 2 

我该如何实现?

【问题讨论】:

  • DEBUG 显示命令 before 执行和解析。顺便说一句,$apple=1 是无效的(除非您使用 Perl 进行编码)。

标签: bash syslog


【解决方案1】:

这是一种方法:

#!/bin/bash

apple=1
orange=2
set -x

exec 2> >(logger)
echo $apple $orange

我们正在将 stderr(设置 -x 路由到 stderr,文件描述符 2)重定向到记录器程序。

在我的 /var/log/messages 我得到:

Aug 23 08:16:07 yogi logger: + echo 1 2

【讨论】:

  • 这是一个很好的答案!你能详细描述一下 exec2> >(logger) 是做什么的吗?
  • 是的,set -x 输出到标准错误。
  • exec 2> >(logger) 将文件描述符 2 (stderr) 重定向到 logger 程序的标准输入。它被称为进程替换(参见man bash)。
  • 嘿,还有一个后续问题,+号是什么意思?
  • 想一想,在这里设置PS4='$0'(脚本的名称)可能有用。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2019-10-14
  • 1970-01-01
  • 1970-01-01
  • 2015-10-02
  • 2014-12-24
  • 1970-01-01
  • 2019-03-29
相关资源
最近更新 更多