• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Golang通过SSH执行交换机操作实现

    简单实现通过输入指令,两步执行交换机命令。

    ​ 存在问题:

    ​ 不过我的目的已经达到,我主要是了解ssh的使用。

    package main
    
    import (
      "bufio"
      "fmt"
      "golang.org/x/crypto/ssh"
      "log"
      "os"
      "strings"
      "sync"
    )
    
    //获取账号和密码的对应关系
    type HostPassword struct {
      Host string
      Username string
      Password string
    }
    var (
      a,b string //临时存储变量
      commands = []string{} //执行命令组
      hp []HostPassword //保存账号和密码
      wg sync.WaitGroup  //执行goroutine
    
    )
    func main() {
      //1. 选择交换机
      //2. 输入要执行命令
      //3. 建立会话连接
      //4. 新建session,并执行命令
    
      //1. 选择操作交换机
      // 1.1 输入要执行交换机
      fmt.Println("请输入计划执行命令的交换机账号和密码,账号密码直接使用|分割,多个账号密码之间使用;分割,例如admin;192.168.56.10;h3csw1|admin;192.168.56.11;h3csw2")
      _, err := fmt.Scanln(a)
      if err != nil {
        log.Fatal("输入错误:",err)
      }
      fmt.Println("请输入要执行的命令行,以;号间隔")
      //1.1.1切割交换机命令
      switchgroups := strings.Split(a, "|")
      length := len(switchgroups)
      hp = make([]HostPassword,length)
      for i,singleswitch := range switchgroups{
        hp[i]=HostPassword{}
        switchsplit := strings.Split(singleswitch, ";")
        hp[i].Username=switchsplit[0]
        hp[i].Host=switchsplit[1]
        hp[i].Password=switchsplit[2]
      }
    
      // 1.2 输入要执行命令
      input := bufio.NewReader(os.Stdin)
      b, err := input.ReadString('\n')
      if err != nil {
        log.Fatal("输入错误",err)
      }
      commands = strings.Split(b, ";")
    
      //2. 执行交换机操作
      err = SshSwitch(hp)
      if err != nil {
        log.Fatalln(err)
      }
    
      // 同步等待
      wg.Wait()
    }
    
    //建立ssh连接
    func SshSwitch(hostpasswords []HostPassword) (error){
      //循环获取hostpasswords的账号和密码
      for i,_ := range hp{
        //添加同步组,下面会执行goroutin
        wg.Add(1)
        config := ssh.ClientConfig{
          Config:      ssh.Config{
            Ciphers:    []string{"aes128-ctr", "aes192-ctr", "aes256-ctr", "aes128-gcm@openssh.com", "arcfour256", "arcfour128", "aes128-cbc", "3des-cbc", "aes192-cbc", "aes256-cbc"},
          }, //添加了很多加密方式,为了应对不同的密码规则
          User:       hp[i].Username,
          Auth:       []ssh.AuthMethod{
            ssh.Password(hp[i].Password),
          },
          HostKeyCallback:  ssh.InsecureIgnoreHostKey(), //此处相当于执行nil,但是并不安全
        }
        client, err := ssh.Dial("tcp",hp[i].Host+":22", config)
        if err != nil {
          log.Fatalln("建立ssh连接错误:",err)
          return err
        }
        //执行goroutine,但是没有返回错误。
        go HandleSession(client, commands,wg)
    
      }
      return nil
    }
    
    //建立session,执行命令。
    func HandleSession(client *ssh.Client,commands []string,wg *sync.WaitGroup) error {
      //建立session
      session, err := client.NewSession()
      if err != nil {
        log.Fatalln("创建session出错",err)
        return err
      }
      //延迟关闭session
      defer session.Close()
    
      //设置terminalmodes的方式
      modes := ssh.TerminalModes{
        ssh.ECHO:     0,   // disable echoing
        ssh.TTY_OP_ISPEED: 14400, // input speed = 14.4kbaud
        ssh.TTY_OP_OSPEED: 14400, // output speed = 14.4kbaud
      }
      //建立伪终端
      err = session.RequestPty("xterm",80,40,modes)
      if err != nil {
        log.Fatal("创建requestpty出错",err)
        return err
      }
      //设置session的标准输入是stdin
      stdin, err := session.StdinPipe()
      if err != nil {
        log.Fatal("输入错误",err)
        return err
      }
      //设置session的标准输出和错误输出分别是os.stdout,os,stderr.就是输出到后台
      session.Stdout = os.Stdout
      session.Stderr = os.Stderr
      err = session.Shell()
      if err != nil {
        log.Fatal("创建shell出错",err)
        return err
      }
      //将命令依次执行
      for _, cmd := range commands {
        fmt.Println(cmd)
        _, err = fmt.Fprintf(stdin, "%s\n", cmd)
        if err != nil {
          log.Fatal("写入stdin出错",err)
          return err
        }
      }
    
      //执行等待
      err = session.Wait()
      if err != nil {
        log.Fatal("等待session出错",err)
        return err
      }
      //减少同步组的次数
      wg.Done()
      return nil
    }

    到此这篇关于Golang通过SSH执行交换机操作实现的文章就介绍到这了,更多相关Golang SSH执行交换机内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • golang中连接mysql数据库
    • Golang操作MySql数据库的完整步骤记录
    • 如何利用Golang解析读取Mysql备份文件
    • Golang中如何对MySQL进行操作详解
    • golang gorm 操作mysql及gorm基本用法
    • golang 通过ssh代理连接mysql的操作
    上一篇:Go语言Mock使用基本指南详解
    下一篇:golang实现单点登录系统(go-sso)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Golang通过SSH执行交换机操作实现 Golang,通过,SSH,执行,交换机,