golang 执行命令行的实现
作者:molaifeng 时间:2024-04-28 09:14:40
一般情况下,在 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
标签:golang,命令行
0
投稿
猜你喜欢
使用Python神器对付12306变态验证码
2021-01-19 00:14:02
python 实现创建文件夹和创建日志文件的方法
2023-07-07 11:35:10
利用Python多处理库处理3D数据详解
2021-03-05 18:11:18
python Plotly绘图工具的简单使用
2023-06-13 01:16:17
python 装饰器的基本使用
2021-04-01 07:12:50
numpy.sum()的使用详解
2023-01-04 15:19:24
线上MYSQL同步报错故障处理方法总结(必看篇)
2024-01-27 14:57:33
python在html中插入简单的代码并加上时间戳的方法
2022-06-19 05:33:01
python3获取当前文件的上一级目录实例
2021-06-03 02:22:22
简单的MySQL备份与还原方法分享
2024-01-24 22:51:13
Python可视化神器pyecharts之绘制箱形图
2021-08-04 03:40:53
numpy.std() 计算矩阵标准差的方法
2023-06-04 19:50:34
详解MySQL性能优化(二)
2024-01-23 13:10:47
Go mod包管理工具详解
2024-04-30 10:08:11
Python实现屏幕代码雨效果的示例代码
2021-08-29 12:48:09
基于Nodejs的Tcp封包和解包的理解
2024-05-11 10:13:43
Python如何使用k-means方法将列表中相似的句子归类
2022-11-01 21:16:32
使用Python开发游戏运行脚本成功调用大漠插件
2021-03-09 21:05:53
SQL Server 2008图文安装教程第1/2页
2024-01-12 18:54:21
在Pycharm中使用GitHub的方法步骤
2021-04-27 04:46:48