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

博客介绍了使用exec.CommandContext处理外部命令超时的情况,还给出使用sleep不带参数的错误示例,指出命令执行错误不会导致ctx.Err()错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用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()错误。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值