欢迎访问田飞雨的博客,如果想一起学习linux请加此群! linux学习小群    

Golang 调用 Linux 命令

Golang struggling 977次浏览 已收录 0个评论

Golang 中可以使用 os/exec 来执行 Linux 命令,下面是一个简单的示例:

    package main
    
    import (
        "fmt"
        "io/ioutil"
        "os/exec"
    )
    
    func main() {
        cmd := exec.Command("/bin/bash", "-c", `df -lh`)
    
        //创建获取命令输出管道
        stdout, err := cmd.StdoutPipe()
        if err != nil {
            fmt.Printf("Error:can not obtain stdout pipe for command:%s\n", err)
            return
        }
    
        //执行命令
        if err := cmd.Start(); err != nil {
            fmt.Println("Error:The command is err,", err)
            return
        }
    
        //读取所有输出
        bytes, err := ioutil.ReadAll(stdout)
        if err != nil {
            fmt.Println("ReadAll Stdout:", err.Error())
            return
        }
    
        if err := cmd.Wait(); err != nil {
            fmt.Println("wait:", err.Error())
            return
        }
        fmt.Printf("stdout:\n\n %s", bytes)
    }

或者创建一个缓冲读取器按行读取:

    package main
    
    import (
        "bufio"
        "fmt"
        "os/exec"
    )
    
    func main() {
        cmd := exec.Command("/bin/bash", "-c", `df -lh`)
    
        //创建获取命令输出管道
        stdout, err := cmd.StdoutPipe()
        if err != nil {
            fmt.Printf("Error:can not obtain stdout pipe for command:%s\n", err)
            return
        }
    
        //执行命令
        if err := cmd.Start(); err != nil {
            fmt.Println("Error:The command is err,", err)
            return
        }
    
        //使用带缓冲的读取器
        outputBuf := bufio.NewReader(stdout)
    
        for {
    
            //一次获取一行,_ 获取当前行是否被读完
            output, _, err := outputBuf.ReadLine()
            if err != nil {

                // 判断是否到文件的结尾了否则出错
                if err.Error() != "EOF" {
                    fmt.Printf("Error :%s\n", err)
                }
                return
            }
            fmt.Printf("%s\n", string(output))
        }
    
        //wait 方法会一直阻塞到其所属的命令完全运行结束为止
        if err := cmd.Wait(); err != nil {
            fmt.Println("wait:", err.Error())
            return
        }
    }

输出结果:

在写这句 if err.Error() != "EOF" 时,一直以为可以直接将 error 类型直接转为 string 然后就可以比较了,所以刚开始写的代码是这样的 if string(err) != "EOF",但是一直报下面这个错误:

    # command-line-arguments
    ./exec_command.go:36: cannot convert err (type error) to type string

于是查了下才明白,error 类型本身是一个预定义好的接口,里面定义了一个method

    type error interface {
        Error() string
    }

所以 err.Error() 才是一个 string 类型的返回值。


DevOps-田飞雨 》》转载请注明源地址
喜欢 (2)or分享 (0)
发表我的评论
取消评论
*

表情 贴图 加粗 链接 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址