在用Go的exec启动子进程的时候,类似于date命令之类的子进程,命令执行完,可以等子进程执行完成后获取子进程的输出。

package main

import (
	"fmt"
	"log"
	"os/exec"
)

func main() {
	out, err := exec.Command("date").Output()
	if err != nil {
		log.Fatal(err)
	}
	fmt.Printf("The date is %s\n", out)
}

但是,如果子进程是类似于top这类常驻内存的子进程怎么办的,官方的手册并没有给出例子,最近我在做一个小工具的时候,需要获取常驻内存子进程的输出,找到了解决方案

package main

import (
	"os/exec"
	"os"
	"bytes"
	"log"
	"time"
	"fmt"
)

func main() {
	cmd := exec.Command("top")
	cmd.Stdin = os.Stdin
	var out bytes.Buffer
	cmd.Stdout = &out
	cmd.Stderr = &out
	go func() {
		for {
			l, err := out.ReadString('\n')
			if err != nil && err.Error() != "EOF" {
				log.Print(err)
				time.Sleep(100 * time.Millisecond)
				continue
			}
			fmt.Print(l)
			time.Sleep(100 * time.Millisecond)
		}
	}()
	cmd.Run()
}

这样就可以持续获取子进程的输出了

更多架构、PHP、GO相关踩坑实践技巧请关注我的公众号:PHP架构师