Debian系统中如何将Go程序的错误消息重定向到文件

9次阅读

Debian系统中如何将Go程序的错误消息重定向到文件

debian系统中运行go编写的websocket服务器时,panic等错误信息默认输出到标准错误(stderr),而非标准输出(stdout),因此仅用 ./server > err 无法捕获错误日志;需同时重定向stderr,推荐使用 2>&1 将stderr合并至stdout再统一写入文件。

linux shell 中,标准流有三个:

  • stdin(文件描述符 0):输入流
  • stdout(文件描述符 1):正常输出流
  • stderr(文件描述符 2):错误输出流

./server > err 仅重定向了 stdout(即 1> err),而 panic、log.Fatal、fmt.Fprintln(os.Stderr, …) 等均写入 stderr,因此仍打印到终端。

✅ 正确做法是显式重定向 stderr:

./server > err 2>&1

其中 2>&1 表示“将文件描述符 2(stderr)重定向到当前 stdout 的目标(即文件 err)”。该语法要求 >(即 stdout 重定向)必须先出现,否则 &1 无定义。

? 其他实用变体:

  • 仅保存错误,丢弃正常输出(适用于调试时聚焦 panic):
    ./server 2> err 1>/dev/null
  • 追加模式写入(避免覆盖已有日志)
    ./server >> err 2>&1
  • 同时查看实时输出并记录日志(需安装 tee):
    ./server 2>&1 | tee err

⚠️ 注意事项:

  • go 中使用 log.printf 默认输出到 stderr,而 fmt.Println 输出到 stdout;若需统一日志行为,建议全程使用 log 包并配置 log.SetOutput()。
  • 在 systemd 服务中部署时,应通过 StandardOutput= 和 StandardError= 指令配置日志重定向,而非依赖 shell 重定向。
  • 确保目标目录可写,且 err 文件路径为绝对路径(如 /var/log/server.err)以提升健壮性。

掌握 stderr 重定向是 Linux 服务运维的基础技能——一次正确配置,即可让 panic 日志持久化,大幅提升问题定位效率。

text=ZqhQzanResources