golang 執行命令行的實現
一般情況下,在 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
到此這篇關於golang 執行命令行的實現的文章就介紹到這瞭,更多相關golang 執行命令行內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 詳解golang執行Linux shell命令完整場景下的使用方法
- Golang執行cmd命令行的方法
- Go語言入門exec的基本使用示例
- golang執行命令操作 exec.Command
- 使用Golang快速構建出命令行應用程序