SNMP: ответный PDU слишком большой - PullRequest
0 голосов
/ 03 апреля 2019

Мне нужно протестировать код драйвера на основе библиотеки snmp ++. Когда я запустил этот код драйвера, я распечатал следующий журнал ошибок

  • «Ошибка регистра ловушки Snmp: SNMP: слишком большой отклик PDU»

Я использую SNMP ++ v3.2.25. Я нашел симулятор SNMP в сети и отправил его драйверу SNMP. До сих пор распечатываю журнал ошибок

  • «Ошибка регистра ловушки Snmp: SNMP: слишком большой отклик PDU».

Симулятор SNMP, который я использовал, был SnmpTrapGen V1.1. Я отправил команду CMD для

  • "SnmpTrapGen.Exe -r: 172.20.31.126 -p: 161 -v: 3 -to: 1.3.6.1.4.1.2011.2.15.2.4.3.3.0.1"
int ScsSnmp::init_snmp()
{
    Snmp::socket_startup();
    int status;
//  UdpAddress address(m_local_addr);
    m_snmp = new Snmp(status/*,address*/);
    if (( m_snmp == NULL) || ( status != SNMP_CLASS_SUCCESS))
    {
        printlog(LOGE_SNMP + m_link,"constructing Snmp Object failed ");
    }
    else
    {
        TargetCollection targets;
        OidCollection trapids;
        Oid trapoid = OidAlarmReportNotificationType;
        Oid heartoid = OidHeartbeatNotificationType;
        trapids += trapoid;
        trapids += heartoid;
        m_snmp->notify_set_listen_port(TRAP_LISTEN_PORT);
        ScsSnmp* myself = this;
        if ( status = m_snmp->notify_register( trapids, targets,my_trap_callback,myself) != SNMP_CLASS_SUCCESS)
        {
            printlog(LOGE_SNMP + m_link,"Snmp Trap Register Error : %s ",m_snmp->error_msg(status));
            return -1;
        }
        m_snmp->start_poll_thread(1000);    //1000ms
    }
    return 0;
}

void ScsSnmp::my_trap_callback (int reason, Snmp *session,Pdu &pdu, SnmpTarget &target, void *data)
{
    ScsSnmp* scssnmp = (ScsSnmp*)data;
    printlog(LOGE_SNMP + scssnmp->m_link,"start my_trap_callback");
    if ( reason == SNMP_CLASS_NOTIFICATION) 
    {
        Vb nextVb;
        GenAddress addr;
        target.get_address(addr);
        IpAddress from(addr);   
        Oid notify_id,ent;
        pdu.get_notify_id(notify_id);
        pdu.get_notify_enterprise(ent);
        if (notify_id == OidAlarmReportNotificationType)
        {
            memset(scssnmp->m_alarm_msg,0,128);
            memset(scssnmp->m_alarm_info.station,0,64);
            memset(scssnmp->m_alarm_info.subsystem,0,64);
            memset(scssnmp->m_alarm_info.devicetype,0,64);
            memset(scssnmp->m_alarm_info.device,0,64);
            memset(scssnmp->m_alarm_info.alarm_msg,0,128);
            for (int i = 0;i<pdu.get_vb_count();i++)
            {
                pdu.get_vb(nextVb, i);
                scssnmp->process_alarm_vb(nextVb);
            }
            memset(scssnmp->m_alarm_buf,0,512);
            memcpy(scssnmp->m_alarm_buf,&scssnmp->m_alarm_head,sizeof(alarm_head));
            memcpy(scssnmp->m_alarm_buf+sizeof(alarm_head),&scssnmp->m_alarm_info,sizeof(alarm_event_info));
            bool ret = scssnmp->m_ctrl_inf->addAlarm(scssnmp->m_alarm_buf,512);
            if (ret)
            {
                printlog(LOGE_SNMP + scssnmp->m_link,"add an event alarm success !");
            }
            else
            {
                printlog(LOGE_SNMP + scssnmp->m_link,"add an event alarm failed !");
            }

        }
        else if (notify_id == OidHeartbeatNotificationType)
        {
            printlog(LOGE_SNMP + scssnmp->m_link,"get a heartbeat !");
        }
        else
        {
            printlog(LOGE_SNMP + scssnmp->m_link,"Trap notify id is wrong,id=%s",notify_id.get_printable());
        }

    }
    else
    {
        printlog(LOGE_SNMP + scssnmp->m_link,"Trap Receive Error = ",session->error_msg(reason));
    }
    printlog(LOGE_SNMP + scssnmp->m_link,"end my_trap_callback");
}

Я хочу отправлять SNMP-ловушки через эмулятор. Затем драйвер SNMP получает данные и распечатывает их. Проще говоря, вы хотите проверить, работает ли интерфейс данных. Но фактический интерфейс получения продолжает печатать журнал ошибок

  • «Ошибка регистра ловушки Snmp: SNMP: слишком большой отклик PDU».
...