首页 > 后端开发 > Golang > 如何在保持顺序的同时将命令输出重定向到控制台和日志文件?

如何在保持顺序的同时将命令输出重定向到控制台和日志文件?

DDD
发布: 2024-11-04 03:42:01
原创
247 人浏览过

How to Redirect Command Output to Both Console and Log File while Maintaining Order?

将命令输出重定向到控制台和日志文件

要同时显示和记录命令的 stdout 和 stderr,同时保留输出顺序,您可以使用标准库的 io .MultiWriter.

代码片段

<code class="go">package main

import (
    "io"
    "log"
    "os"
    "os/exec"
)

func main() {
    // Logging capability
    f, err := os.OpenFile("log.log", os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666)
    if err != nil {
        log.Fatalf("Error opening file: %v", err)
    }
    defer f.Close()
    mwriter := io.MultiWriter(f, os.Stdout)
    cmd := exec.Command("ls")
    cmd.Stderr = mwriter
    cmd.Stdout = mwriter
    err = cmd.Run() //blocks until sub process is complete
    if err != nil {
        panic(err)
    }
}</code>
登录后复制

说明

  1. 打开一个文件进行日志记录并创建一个结合文件和标准输出的 MultiWriter。
  2. 创建一个命令并指定两者stdout 和 stderr 应使用 MultiWriter。
  3. 执行命令,该命令会将输出打印到控制台和日志实时文件,同时保持原始输出顺序。

以上是如何在保持顺序的同时将命令输出重定向到控制台和日志文件?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板