利用Golang如何调用Linux命令详解

 更新时间:2017年05月05日 11:06:11   作者:田飞雨  
这篇文章主要给大家介绍了Golang中使用os/exec来执行 Linux 命令的相关资料,文中给出了详细的示例代码,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。

本文介绍的是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 类型的返回值。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

您可能感兴趣的文章:

相关文章

  • golang高性能的http请求 fasthttp详解

    golang高性能的http请求 fasthttp详解

    fasthttp 是 Go 的快速 HTTP 实现,当前在 1M 并发的生产环境使用非常成功,可以从单个服务器进行 100K qps 的持续连接,总而言之,fasthttp 比 net/http 快 10 倍,下面通过本文给大家介绍golang fasthttp http请求的相关知识,一起看看吧
    2021-09-09
  • 一文搞懂Go语言标准库strconv

    一文搞懂Go语言标准库strconv

    strconv包实现了基本数据类型和其字符串表示的相互转换,本文主要介绍Go语言标准库strconv,想要学习strconv标准库的可以了解一下
    2023-04-04
  • Go语言指针访问结构体的方法

    Go语言指针访问结构体的方法

    这篇文章主要介绍了Go语言指针访问结构体的方法,涉及Go语言指针及结构体的使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-02-02
  • gin通过go build -tags实现json包切换及库分析

    gin通过go build -tags实现json包切换及库分析

    这篇文章主要为大家介绍了gin通过go build -tags实现json包切换及库分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • Golang源码分析之golang/sync之singleflight

    Golang源码分析之golang/sync之singleflight

    golang/sync库拓展了官方自带的sync库,提供了errgroup、semaphore、singleflight及syncmap四个包,本次先分析第一个包errgroup的源代码,下面这篇文章主要给大家介绍了关于Golang源码分析之golang/sync之singleflight的相关资料,需要的朋友可以参考下
    2022-11-11
  • Systemd集成Golang二进制程序的方法

    Systemd集成Golang二进制程序的方法

    这篇文章主要介绍了Systemd集成Golang二进制程序的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-10-10
  • 浅析Golang中的内存逃逸

    浅析Golang中的内存逃逸

    内存逃逸分析是go的编译器在编译期间,根据变量的类型和作用域,确定变量是堆上还是栈上。本文将通过示例浅析一下Golang中的内存逃逸,需要的可以了解一下
    2022-10-10
  • goland -sync/atomic原子操作小结

    goland -sync/atomic原子操作小结

    这篇文章主要介绍了goland -sync/atomic原子操作,原子操作能够保证执行期间是连续且不会被中断(变量不会被其他修改,mutex可能存在被其他修改的情况),本文给大家介绍的非常详细,需要的朋友参考下
    2022-08-08
  • goland设置颜色和字体的操作

    goland设置颜色和字体的操作

    这篇文章主要介绍了goland设置颜色和字体的操作方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-05-05
  • Go 实战单队列到优先级队列实现图文示例

    Go 实战单队列到优先级队列实现图文示例

    这篇文章主要为大家介绍了Go 实战单队列到优先级队列图文示例实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07

最新评论