使用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     : []
cmdarray := []string{"-c","")}
ctx.Err : [<nil>]
error   : [exit status 1]
out     : [usage: sleep seconds
]

可以命令的执行错误不会导致ctx.Err()错误。

 

 

小编说

如果觉得编程之家网站内容还不错,欢迎将编程之家推荐给好友。