进入lang + snmp大声笑(错误连接处理)

时间:2019-05-19 12:35:54

标签: loops go snmp

我在golnag上做一台服务器,我需要对许多设备执行SNMP命令,其中一些设备无法建立连接(或暂时失去连接) 我想要消息“没有连接”或“错误”,然后继续运行programm

Ubuntu 18.04 //转到1.8 //从https://github.com/soniah/gosnmp进入SNMP

package main

import (
    "fmt"
    "log"
    "time"
    g "github.com/soniah/gosnmp"
)

func main() {
    g.Default.Target = string("192.168.10.1")
    err := g.Default.Connect()
    if err != nil {
        log.Fatalf("Connect() err: %v", err)
        fmt.Println("Fail connection") // want this message in this case  !!!!!
    }
    defer g.Default.Conn.Close()

    oids := []string{"1.3.6.1.2.1.1.4.0", "1.3.6.1.2.1.1.7.0"} 
    result, err2 := g.Default.Get(oids)  
    if err2 != nil {
        log.Fatalf("Get() err: %v", err2)
        fmt.Println("Error read OID") // want this message in this case !!!!!
    }

    for i, variable := range result.Variables {
        fmt.Printf("%d: oid: %s ", i, variable.Name)

        switch variable.Type {
        case g.OctetString:
            fmt.Printf("string: %s\n", string(variable.Value.([]byte)))
        default:
            fmt.Printf("number: %d\n", g.ToBigInt(variable.Value))
        }
    }
}

如果没有连接,我会收到此结果,并中断pogramm的运行

2019/05/19 15:11:33 Get() err: Request timeout (after 3 retries)
exit status 1

我想要这样的东西

"Fail connection"   or  "Error read OID"

接下来,我想继续运行programm

2 个答案:

答案 0 :(得分:0)

您在留下评论的行中有无法访问的代码。

只需为log.Fatalf使用正确的字符串值:

if err != nil {
  log.Fatalf("Fail connection, error: %v", err)
}

或者如果您不想退出:

if err != nil {
  log.Printf("Fail connection, error: %v", err)
}

答案 1 :(得分:-1)

@Sergey Narozhnyy @谢谢!最大的错误是处理“ result.Variables”。如果没有连接,则没有“结果”