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!