Editor PHP Banana akan memperkenalkan dalam artikel ini cara menulis log ke terminal dan fail. Semasa proses pembangunan, log adalah sangat penting, kerana ia boleh membantu kami menjejak dan menyahpepijat masalah kod. Menulis log ke terminal dan ke fail adalah dua kaedah biasa Mereka masing-masing mempunyai kelebihan dan keburukan sendiri Anda boleh memilih kaedah yang sesuai mengikut keperluan khusus anda. Seterusnya, kami akan membincangkan secara terperinci cara menggunakan kod PHP untuk menulis log ke terminal dan fail, dan memperkenalkan beberapa fungsi dan teknik penulisan log biasa untuk membantu pembangun mengurus log dengan lebih baik.
Saya mempunyai fungsi ini untuk menulis log ke terminal dan fail log:
// Run an executable and print its log in real-time and print its log into a file too. func RunWithLog(pthExe string, arg []string, fLog *os.File, dir string) error { cmd := exec.Command(pthExe, arg...) if dir != "" { cmd.Dir = dir } stdout, err := cmd.StdoutPipe() if err != nil { return err } stderr, err := cmd.StderrPipe() if err != nil { return err } var wg sync.WaitGroup wg.Add(4) go streamRealTime(stdout, &wg) go streamRealTime(stderr, &wg) go streamToLogFile(stdout, fLog, &wg) go streamToLogFile(stderr, fLog, &wg) err = cmd.Start() if err != nil { return err } wg.Wait() err = cmd.Wait() return err } func streamRealTime(output io.ReadCloser, wg *sync.WaitGroup) { defer wg.Done() scanner := bufio.NewScanner(output) scanner.Split(bufio.ScanRunes) for scanner.Scan() { fmt.Print(scanner.Text()) } err := scanner.Err() if err != nil { log.Printf("error: write log to terminal: %s", err.Error()) } } func streamToLogFile(output io.ReadCloser, fLog *os.File, wg *sync.WaitGroup) { defer wg.Done() scanner := bufio.NewScanner(output) scanner.Split(bufio.ScanRunes) for scanner.Scan() { _, err := fLog.WriteString(scanner.Text()) if err != nil { log.Printf("error: write log to file: %s", err.Error()) } } err := scanner.Err() if err != nil { log.Printf("error: write log to file: %s", err.Error()) } }
Panggilan fungsi di atas:
// Log file. fLog, err := os.OpenFile(pathLog, os.O_APPEND, os.ModeAppend) if err != nil { return err } defer fLog.Close() err = RunWithLog(pathExe, []string{"-b"}, fLog, workDir) // ...
Masalahnya ialah beberapa baris log dicetak ke terminal dan beberapa baris dicetak ke fail, seperti ini:
Bagaimana untuk memastikan semua baris log dicetak ke terminal dan fail?
Log dicetak ke terminal dan fail melalui:
// Run an executable and print its log real-time and print its log into a file too. func RunWithLog(pthExe string, arg []string, fLog *os.File, dir string) error { cmd := exec.Command(pthExe, arg...) if dir != "" { cmd.Dir = dir } stdout, err := cmd.StdoutPipe() if err != nil { return err } stderr, err := cmd.StderrPipe() if err != nil { return err } var wg sync.WaitGroup wg.Add(2) go streamLogs(stdout, fLog, &wg) go streamLogs(stderr, fLog, &wg) err = cmd.Start() if err != nil { return err } wg.Wait() err = cmd.Wait() return err } // Stream logs to both terminal and a file. func streamLogs(output io.ReadCloser, fLog *os.File, wg *sync.WaitGroup) { defer wg.Done() scanner := bufio.NewScanner(output) scanner.Split(bufio.ScanRunes) for scanner.Scan() { // Stream to terminal: fmt.Print(scanner.Text()) // Stream to a file: _, err := fLog.WriteString(scanner.Text()) if err != nil { log.Printf("error: write log to file: %s", err.Error()) } } err := scanner.Err() if err != nil { log.Printf("error: write log to terminal: %s", err.Error()) } }
Lognya sama:
Atas ialah kandungan terperinci Tulis log ke terminal dan fail. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!