Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk Mengalihkan Output Perintah ke Konsol dan Fail Log Secara Serentak dalam Go?

Bagaimana untuk Mengalihkan Output Perintah ke Konsol dan Fail Log Secara Serentak dalam Go?

Susan Sarandon
Susan Sarandonasal
2024-11-03 22:07:30983semak imbas

How to Redirect Command Output to Console and Log File Simultaneously in Go?

Mengubah hala Output Perintah ke Konsol dan Fail Log Secara Serentak

Untuk mengubah hala stdout dan stderr perintah ke konsol dan fail log dalam masa nyata, anda boleh menggunakan jenis io.MultiWriter dalam Go. Begini caranya:

Dalam coretan kod yang disediakan, kod dilencongkan hanya ke konsol kerana medan Stdout dan Stderr cmd ditetapkan kepada os.Stdout dan os.Stderr masing-masing. Untuk mengubah hala ke kedua-dua konsol dan fail log, ubah suai kod seperti berikut:

<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("php", "randomcommand.php")
    cmd.Stdout = mwriter
    cmd.Stderr = mwriter

    if err := cmd.Run(); err != nil {
        log.Fatal(err)
    }
}</code>

Pembolehubah mwriter ialah contoh io.MultiWriter yang mengandungi kedua-dua fail log dan output standard. Dengan menetapkan Stdout dan Stderr arahan kepada mwriter ini, output arahan ditulis ke kedua-dua lokasi secara serentak.

Skrip randomcommand.php boleh kekal sama, berselang seli antara menulis kepada stdout dan stderr 20 kali. Apabila anda menjalankan program Go, output akan dicetak ke konsol dalam masa nyata dan juga dilog ke fail log yang ditentukan, mengekalkan susunan penulisan yang tepat ke stdout dan stderr.

Atas ialah kandungan terperinci Bagaimana untuk Mengalihkan Output Perintah ke Konsol dan Fail Log Secara Serentak dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn