golang并发ping主机的方法

纯洁美丽。它化做雪花,用自己洁白的生躯覆盖在大地上。此时,一切都是银装素裹,一副冰清玉洁的模样。光秃秃的树枝上缀满了朵朵洁白的 "梨花 ",风一吹,花儿纷纷飘落,好似一只只银白色的蝴蝶在空中偏偏起舞。 "忽如一夜春风来,千树万树梨花开 ",这句诗不正是赞美冬天的吗?

利用了golang对高并发的良好支持,同目录下将ip每行一个写入pinglist.txt文件即可

其实这个功能用linux一条命令就能搞定:

cat pinglist.txt | xargs -P 10 -I {} ping -fc 100 {}

package main

import (
  "bufio"
  "bytes"
  "fmt"
  "io"
  "io/ioutil"
  "log"
  "os"
  "os/exec"
  "strings"
  "sync"
  "runtime"
)

func RunCMD(command string) string {
  in := bytes.NewBuffer(nil)
  cmd := exec.Command("sh")
  cmd.Stdin = in
  in.WriteString(command + "\n")
  stdout, err := cmd.StdoutPipe()
  if err != nil {
    log.Fatal(err)
  }
  defer stdout.Close()
  if err := cmd.Start(); err != nil {
    log.Fatal(err)
  }
  opBytes, err := ioutil.ReadAll(stdout)
  if err != nil {
    log.Fatal(err)
  }
  return string(opBytes)
}

func ping(ip string) string {
  cmd := "ping -fc 100 " + ip
  return RunCMD(cmd)
}

var ips = []string{}

func main() {
  runtime.GOMAXPROCS(runtime.NumCPU())
  fileName := "pinglist.txt"
  f, err := os.Open(fileName)
  if err != nil {
    fmt.Println(err)
  }
  buf := bufio.NewReader(f)
  for {
    line, err := buf.ReadString('\n')
    line = strings.TrimSpace(line)
    if err != nil {
      if err == io.EOF {
        //fmt.Println("File read over!")
        break
      }
      fmt.Println(err)
    }
    ips = append(ips, line)
  }
  wg := &sync.WaitGroup{}
  ch := make(chan string, len(ips))
  //fmt.Println(ips)
  for i:= 0; i < len(ips); i++ {
    wg.Add(1)
    go func(i int) {
      ch <- ping(ips[i])
      wg.Done()
    }(i)
  }
  wg.Wait()

  //fmt.Println(len(ch))
  for i := 0; i < len(ips); i++ {
    fmt.Println(<-ch)
  }
}

以上这篇golang并发ping主机的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

您可能有感兴趣的文章
golang并发编程的如何实现

golang如何实现redis的延时消息队列功能示例

golang中range在slice和map遍历中的注意事项

Golang命令行进行debug调试操作

golang的空标识符理解