您的位置 首页 golang

golang执行外部命令超时处理的exec.CommandContext

使用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

关于作者: 智云科技

热门文章

发表评论

您的电子邮箱地址不会被公开。

网站地图