2011-08-05 2 views
0

SNMP 서비스를 폴링 할 때 홀수 자식 프로세스 오류의 원인을 확인하고 제거하는 데 도움이 필요합니다."select() error [No child processes]"로 Net :: SNMP :: Dispatcher가 실패하는 이유는 무엇입니까?

SNMP 연결하는 동안, 나는 장치 이름을 폴링 SNMP 연결을 확인 시간이 종료 될 때까지 :

sub snmp_close { 
    my $self = shift; 

    $self->{SNMP_SESSION}->close if (defined $self->{SNMP_SESSION} && $self->{SNMP_SESSION}); 
    $self->{SNMP_SESSION} = undef; 
} 

sub { 
    my ($self, $ip, $community) = @_; 
    # If there's a leftover session around, make sure it's closed 
    $self->snmp_close; 

    my ($session, $error) = Net::SNMP->session(
     -hostname => $ip, 
     -community => $community, 
     -nonblocking => 1, 
     -version => 'snmpv2c', 
     -translate => [ 
      -timeticks => 0x0 
     ], 
    ); 

    if (!defined $session) { 
     $self->_logger->logcluck("Can't create SNMP object, error: '$error'"); 
     return; 
    } 

    $self->{SNMP_SESSION} = $session; 

    my $end = time() + 90; 
    while (time < $end) { 
     $self->_logger->debug("Probing for SNMP connectivity, giving up in " . int($end - time()) . " seconds"); 
     my %sysName = $self->get_bulk('1.3.6.1.2.1.1.5'); 
     if(scalar keys %sysName >= 1) { # try polling sysName.. 
      return 1; 
     } 
     else { 
      sleep 5; 
     } 
    } 
    # if we've made it this far there's no hope for snmp... 
    $self->_logger->warn("No SNMP connectivity after 90 seconds"); 
    $self->{SNMP_SESSION} = 0; 
    return; 
} 

sub get_bulk { # return a hash of oid keys and values 
    my ($self, $oid) = @_; 

    $self->_logger->logdie("Not connected; call snmp_connect") if not defined $self->{SNMP_SESSION}; 
    $self->_logger->logdie("Connection failed") if not $self->{SNMP_SESSION}; 

    my %table; 

    my $result = $self->snmp->get_bulk_request(
     -varbindlist => [ $oid ], 
     -maxrepetitions => 20, 
     -callback => [\&_table_callback, $self, \%table, $oid], 
    ); 

    if (!defined $result) { 
     $self->_logger->warn("SNMP error: '" . $self->snmp->error() . "'"); 
     return; 
    } 

    snmp_dispatcher(); 

    use Data::Dumper; my %_table = map {s/\Q$oid.\E//; $_} %table; $self->_logger->debug("SNMP Debug, OID polled: '$oid', response is: " . Dumper(\%_table)); 
    return %table; 
} 

대부분의 시간이 완벽하게 작동하지만 시간 의 일부 비율은 난을 얻을 넷 :: SNMP :: 디스패처 중 치명적인 오류 :

FATAL: select() error [No child processes] at perl/lib/perl5.8/Net/SNMP/Dispatcher.pm line 635. 
    at perl/lib/perl5.8/Net/SNMP/Dispatcher.pm line 635 
     Net::SNMP::Dispatcher::_event_select('Net::SNMP::Dispatcher=HASH(0xaca5ce0)', 4.99994683265686) called at perl/lib/perl5.8/Net/SNMP/Dispatcher.pm line 601 
     Net::SNMP::Dispatcher::_event_handle('Net::SNMP::Dispatcher=HASH(0xaca5ce0)') called at perl/lib/perl5.8/Net/SNMP/Dispatcher.pm line 80 
     Net::SNMP::Dispatcher::activate('Net::SNMP::Dispatcher=HASH(0xaca5ce0)') called at perl/lib/perl5.8/Net/SNMP.pm line 611 
     Net::SNMP::snmp_dispatcher() called at perl/lib/perl5.8/Device.pm line 857 
     Device::get_bulk('Device::Class=HASH(0xb1e405c)', 1.3.6.1.2.1.1.5) called at perl/lib/perl5.8/Device.pm line 824 
     Device::snmp_connect('Device::Class=HASH(0xb1e405c)', 10.0.0.1, 'COMMUNITY_STRING') called at perl/lib/perl5.8/Device.pm line 912 

(라인 857 위, get_bulk에서 snmp_dispatcher입니다)

필자는 새롭고 SNMP에 익숙하지 않은 perl을 새로 도입했습니다. 실제로이 문제를 해결하는 방법을 알고 있습니다. . 해당 메서드는 문제를 분리하는 데 도움이되는 경우 mod_perl CGI 호출에서 실행됩니다.

답변

0

일부 로컬 조사 결과 멀티 코어 시스템의 부작용이 나타났습니다. 하위 프로세스가 다른 코어에서 실행되었고 해당 파이프 파일 핸들을 상위 프로세스가 사용할 수 없었습니다.

관련 문제