脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Golang - golang 执行命令行的实现

golang 执行命令行的实现

2022-08-17 12:22molaifeng Golang

本文主要介绍了golang 执行命令行的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一般情况下,在 golang 中执行一些命令如 git clone,则可以使用 exec.Command 函数

?
1
2
3
4
5
6
7
8
9
10
func RunCommand(path, name string, arg ...string) (msg string, err error) {
    cmd := exec.Command(name, arg...)
    cmd.Dir = path
    err = cmd.Run()
    log.Println(cmd.Args)
    if err != nil {
        log.Println("err", err.Error(), "cmd", cmd.Args)
    }
    return
}

这种写法是没有问题,但是一旦执行出错返回值过于简洁了,比如

?
1
2
3
4
5
6
7
8
func main() {
    msg, err := common.RunCommand("./", "/bin/bash", "-c", "git clone url")
    if err != nil {
        log.Fatal(err)
        return
    }
    log.Println(msg)
}

执行后,返回 exit status 128 这种提示,太抽象了,还得专门去搜索引擎查看,若是想要看出更详细的原因还需如此

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
func RunCommand(path, name string, arg ...string) (msg string, err error) {
    cmd := exec.Command(name, arg...)
    var out bytes.Buffer
    var stderr bytes.Buffer
    cmd.Stdout = &out
    cmd.Stderr = &stderr
    cmd.Dir = path
    err = cmd.Run()
    log.Println(cmd.Args)
    if err != nil {
        msg = fmt.Sprint(err) + ": " + stderr.String()
        err = errors.New(msg)
        log.Println("err", err.Error(), "cmd", cmd.Args)
    }
    log.Println(out.String())
    return
}

再次执行,返回

2022/04/03 20:33:49 [/bin/bash -c git clone url]
2022/04/03 20:33:49 err exit status 128: fatal: repository 'url' does not exist
 cmd [/bin/bash -c git clone url]
2022/04/03 20:33:49 
2022/04/03 20:33:49 exit status 128: fatal: repository 'url' does not exist

 哦,原来是 repository 'url' does not exist 这个原因。

更进一步说下,为啥加了 Stdout 和 Stderr 就能接到值了呢,这是由于有些命令会把错误信息打到 Stdout,而也有些命令会把错误信息打到 Stderr,所以就得把两个都收着。

参考:How to debug “exit status 1” error when running exec.Command in Golang

到此这篇关于golang 执行命令行的实现的文章就介绍到这了,更多相关golang 执行命令行内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/molaifeng/article/details/123943715

延伸 · 阅读

精彩推荐