golang 執(zhí)行命令行的實(shí)現(xiàn)
一般情況下,在 golang 中執(zhí)行一些命令如 git clone,則可以使用 exec.Command 函數(shù)
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 }
這種寫法是沒有問題,但是一旦執(zhí)行出錯(cuò)返回值過于簡潔了,比如
func main() { msg, err := common.RunCommand("./", "/bin/bash", "-c", "git clone url") if err != nil { log.Fatal(err) return } log.Println(msg) }
執(zhí)行后,返回 exit status 128 這種提示,太抽象了,還得專門去搜索引擎查看,若是想要看出更詳細(xì)的原因還需如此
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 }
再次執(zhí)行,返回
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 這個(gè)原因。
更進(jìn)一步說下,為啥加了 Stdout 和 Stderr 就能接到值了呢,這是由于有些命令會把錯(cuò)誤信息打到 Stdout,而也有些命令會把錯(cuò)誤信息打到 Stderr,所以就得把兩個(gè)都收著。
參考:How to debug “exit status 1” error when running exec.Command in Golang
到此這篇關(guān)于golang 執(zhí)行命令行的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)golang 執(zhí)行命令行內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決goland 導(dǎo)入項(xiàng)目后import里的包報(bào)紅問題
這篇文章主要介紹了解決goland 導(dǎo)入項(xiàng)目后import里的包報(bào)紅問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-05-05Golang logrus 日志包及日志切割的實(shí)現(xiàn)
這篇文章主要介紹了Golang logrus 日志包及日志切割的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02go?build失敗報(bào)方法undefined的解決過程
go build命令用于編譯我們指定的源碼文件或代碼包以及它們的依賴包,下面這篇文章主要給大家介紹了關(guān)于go?build失敗報(bào)方法undefined的解決過程,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11基于Golang實(shí)現(xiàn)延遲隊(duì)列(DelayQueue)
延遲隊(duì)列是一種特殊的隊(duì)列,元素入隊(duì)時(shí)需要指定到期時(shí)間(或延遲時(shí)間),從隊(duì)頭出隊(duì)的元素必須是已經(jīng)到期的。本文將用Golang實(shí)現(xiàn)延遲隊(duì)列,感興趣的可以了解下2022-09-09Golang?urfave/cli庫簡單應(yīng)用示例詳解
這篇文章主要為大家介紹了Golang?urfave/cli庫簡單應(yīng)用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09詳解Go并發(fā)編程時(shí)如何避免發(fā)生競態(tài)條件和數(shù)據(jù)競爭
大家都知道,Go是一種支持并發(fā)編程的編程語言,但并發(fā)編程也是比較復(fù)雜和容易出錯(cuò)的。比如本篇分享的問題:競態(tài)條件和數(shù)據(jù)競爭的問題2023-04-04