>백엔드 개발 >Golang >실행 완료를 기다리는 대신 실시간으로 명령 출력을 스트리밍하는 방법은 무엇입니까?

실행 완료를 기다리는 대신 실시간으로 명령 출력을 스트리밍하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-17 21:00:03411검색

How to Stream Command Output in Real-time Instead of Waiting for Execution Completion?

명령 실행 및 출력 스트리밍

문제: 지연된 출력 표시

현재 코드는 명령을 처리하고 실행이 완료된 후에만 출력을 표시합니다. 프로세스가 완료될 때까지 기다리는 대신 출력을 라이브로 스트리밍하는 솔루션을 찾습니다.

해결책: 명령 출력 스트리밍

스트리밍 명령 출력에 다음 접근 방식을 사용합니다.

cmdParams := [][]string{
    {filepath.Join(dir, path), "npm", "install"},
    {filepath.Join(pdir, n.path), "gulp"},
}
for _, cp := range cmdParams {
    log.Printf("Starting %s in folder %s...", cp[1:], cp[0])
    cmd := exec.Command(cp[1], cp[2:]...)
    cmd.Dir = cp[0]

    stdout, err := cmd.StdoutPipe()
    if err != nil {
        log.Printf("%s cmd.StdoutPipe() error: %v\n", cp[1:], err)
        return
    }
    // Start command:
    if err = cmd.Start(); err != nil {
        log.Printf("%s start error: %v\n", cp[1:], err)
        return
    }

    // Stream command output:
    scanner := bufio.NewScanner(stdout)
    scanner.Split(bufio.ScanRunes)
    for scanner.Scan() {
        fmt.Print(scanner.Text())
    }
    if scanner.Err() != nil {
        log.Printf("Reading %s stdout error: %v\n", cp[1:], err)
        return
    }

    // Get execution success or failure:
    if err = cmd.Wait(); err != nil {
        log.Printf("Error running %s: %v\n", cp[1:], err)
        return
    }
    log.Printf("Finished %s", cp[1:])
}

설명

  • cmd.StdoutPipe()는 명령으로 작성된 모든 출력을 제공하는 파이프를 생성합니다.
  • 스캐너 := bufio.NewScanner(stdout)는 파이프의 출력을 읽는 스캐너를 초기화합니다.
  • scanner.Split(bufio.ScanRunes)는 스캐너가 출력의 각 문자(룬)를 읽고 처리하도록 합니다.
  • for 루프는 stdout 파이프에서 문자를 지속적으로 읽고 이를 화면에 인쇄합니다.
  • 명령 실행이 완료된 후 cmd.Wait()는 성공 또는 실패를 확인하고 결과를 기록합니다.

위 내용은 실행 완료를 기다리는 대신 실시간으로 명령 출력을 스트리밍하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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