分享
  1. 首页
  2. 文章

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

CodingCode · · 3611 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

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


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:CodingCode

查看原文:golang执行外部命令超时处理的exec.CommandContext

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
3611 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏