日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

golang?執行命令行的實現_Golang

作者:molaifeng ? 更新時間: 2022-10-12 編程語言

一般情況下,在 golang 中執行一些命令如 git clone,則可以使用 exec.Command 函數

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
}

這種寫法是沒有問題,但是一旦執行出錯返回值過于簡潔了,比如

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 這種提示,太抽象了,還得專門去搜索引擎查看,若是想要看出更詳細的原因還需如此

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

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

欄目分類
最近更新