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
    • 最新
    • 标签
主页 / unix / 问题 / 550035
Accepted
john-jones
john-jones
Asked: 2019-11-03 06:34:14 +0800 CST2019-11-03 06:34:14 +0800 CST 2019-11-03 06:34:14 +0800 CST

将自己的信息添加到错误流

  • 772

众所周知,我们可以使用以下命令将错误重定向到特定文件:

./some_script 2>error_log

我正在运行多个脚本,并希望他们将错误放入单个错误文件中。

有没有办法在每个错误实例前面附加信息,例如脚本名称?这样,错误日志可以记录,例如,发布错误的脚本名称等。

shell-script
  • 2 2 个回答
  • 191 Views

2 个回答

  • Voted
  1. jesse_b
    2019-11-03T06:41:02+08:002019-11-03T06:41:02+08:00

    为您的脚本创建一个错误日志函数。就像是:

    logerr () {
        printf '%s - %s - %s\n' \
        "$(date '+%F:%T')" \
        "$(basename "$0")" \
        "$*" >&2
    }
    

    然后你从你的脚本中调用它,比如:

    if false; then
        : something for pass
    else
        logerr failed to be false
    fi
    

    每次使用2>error_log都会覆盖。error_log您需要使用2>>error_log附加。


    如果您希望能够从其他命令中捕获错误并将它们记录在错误日志中,您可以将它们组合在一起,如下所示:

    #!/bin/bash
    
    logerr () {
        local message=$*
        if [[ ! -t 0 ]]; then
            message=$(</dev/stdin)
        fi
        if [[ -n "$message" ]]; then
            printf '%s - %s - %s\n' \
            "$(date '+%F:%T')" \
            "$(basename "$0")" \
            "$*" >&2
        fi
    }
    
    ls -lts /fake/path 2>&1 >/dev/tty | logerr
    

    确保您将标准输出重定向到您需要的任何适用位置。

    这将允许logerr脚本在打开时从标准输入读取(允许您将程序通过管道传输到 loggerr)。问题是程序会将错误消息发送到 stderr,而您希望它与 stdin 保持分离。

    • 3
  2. Best Answer
    john-jones
    2019-11-03T07:32:11+08:002019-11-03T07:32:11+08:00
    ./thescript.sh 2>&1 1>/dev/null | sed '1 s/^/error_message_starts:\n/' >> error_log;
    

    建立在这里的讨论加上这个:
    https ://stackoverflow.com/questions/2342826/how-to-pipe-stderr-and-not-stdout

    为了添加我们想要的任何东西。我们需要能够管道错误流(fd2)。唯一的可管道输出是 fd1。所以fd2需要重定向到fd1。我们还必须摆脱 fd1,这样它就不会碍事。

    • ./thescript.sh
    • 2>&1 错误流(fd2),去任何 fd1 去。
    • 1>/开发/空。Fd1 刚刚跌落悬崖。现在只有错误日志(fd2),得到管道。
    • | sed .. 将管道放入 sed 中,在前面添加那个东西。
    • >> error_log 将流附加到错误日志
    • 0

相关问题

  • 在awk中的两行之间减去相同的列

  • 打印文件行及其长度的脚本[关闭]

  • 通过命令的标准输出以编程方式导出环境变量[重复]

  • 按分隔符拆分并连接字符串问题

  • MySQL Select with function IN () with bash array

Sidebar

Stats

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

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve