>  기사  >  백엔드 개발  >  순서를 유지하면서 명령 출력을 콘솔과 로그 파일 모두로 리디렉션하는 방법은 무엇입니까?

순서를 유지하면서 명령 출력을 콘솔과 로그 파일 모두로 리디렉션하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-04 03:42:01146검색

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.