在debian系统中运行go编写的websocket服务器时,panic等错误信息默认输出到标准错误(stderr),而非标准输出(stdout),因此仅用 ./server > err 无法捕获错误日志;需同时重定向stderr,推荐使用 2>&1 将stderr合并至stdout再统一写入文件。
Linux shell 中,标准流有三个:
./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 无定义。
? 其他实用变体:
./server 2> err 1>/dev/null
./server >> err 2>&1
./server 2>&1 | tee err
⚠️ 注意事项:
tderr,而 fmt.Println 输出到 stdout;若需统一日志行为,建议全程使用 log 包并配置 log.SetOutput()。 掌握 stderr 重定向是 Linux 服务运维的基础技能——一次正确配置,即可让 panic 日志持久化,大幅提升问题定位效率。