使用exec.CommandContext来处理外部命令的超时
func main() { timeout := 5 ctx, cancel := context.WithTimeout(context.Background(), time.Duration(timeout+5)*time.Second) defer cancel() cmdarray := []string{"-c", fmt.Sprintf("%s %s", "sleep", "10")} cmd := exec.CommandContext(ctx, "bash", cmdarray...) out, err := cmd.CombinedOutput() //if ctx.Err() == context.DeadlineExceeded {} fmt.Printf("ctx.Err : [%v]\n", ctx.Err()) fmt.Printf("error : [%v]\n", err) fmt.Printf("out : [%s]\n", string(out))}
运行结果是:
ctx.Err : [context deadline exceeded]error : [signal: killed]out : []
如果是一个命令错误输出是什么:
下面这个例子是使用sleep不带参数,显示是错误的。cmdarray := []string{"-c", fmt.Sprintf("%s %s", "sleep", "")}
ctx.Err : [<nil>]error : [exit status 1]out : [usage: sleep seconds]
可以命令的执行错误不会导致ctx.Err()错误。
文章来源:智云一二三科技
文章标题:golang执行外部命令超时处理的exec.CommandContext
文章地址:https://www.zhihuclub.com/7450.shtml