Rumah > pembangunan bahagian belakang > Golang > 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
Lepaskan: 2024-11-03 22:07:30
asal
1059 orang telah melayarinya

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>
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan