我一直在做一个定制的SNMP,我在试图让一个代理返回正确的数据时遇到了一个墙。
MIB (通过运行smilint -l 6验证):
IDB-MIB DEFINITIONS ::= BEGIN
IMPORTS
MODULE-IDENTITY, OBJECT-TYPE, Integer32, enterprises
FROM SNMPv2-SMI
MODULE-COMPLIANCE, OBJECT-GROUP FROM SNMPv2-CONF;
idb MODULE-IDENTITY
LAST-UPDATED "201307300000Z" -- Midnight 30 July 2013
ORGANIZATION "*********"
CONTACT-INFO "email: *******"
DESCRIPTION "description"
REVISION "201307300000Z" -- Midnight 29 July 2013
DESCRIPTION "First Draft"
::= { enterprises 42134 }
iDBCompliance MODULE-COMPLIANCE
STATUS current
DESCRIPTION
"Compliance statement for iDB"
MODULE
GROUP testGroup
DESCRIPTION
"This group is a test group"
::= {idb 1}
test2 OBJECT-TYPE
SYNTAX Integer32
UNITS "tests"
MAX-ACCESS read-write
STATUS current
DESCRIPTION
"A test object"
DEFVAL { 5 }
::= { idb 3 }
testGroup OBJECT-GROUP
OBJECTS {
test2
}
STATUS current
DESCRIPTION "all test objects"
::= { idb 2 }
END代理文件:
#!/usr/bin/perl
use NetSNMP::OID(':all');
use NetSNMP::agent(':all');
use NetSNMP::ASN(':all');
sub myhandler {
my ($handler, $registration_info, $request_info, $requests) = @_;
print "Handling request\n";
for ($request = $requests; $request; $request = $request->next()) {
#
# Work through the list of varbinds
#
my $oid = $request->getOID();
print "Got request for oid $oi\n";
if ($request_info->getMode() == MODE_GET) {
if ($oid == new NetSNMP::OID($rootOID . ".3")) {
$request->setValue(ASN_INTEGER, 2);
}
}
}
}
{
$subagent = 0;
print "Running new agent\n";
my $rootOID = ".1.3.6.1.4.1.42134";
my $regoid = new NetSNMP::OID($rootOID);
if (!$agent) {
$agent = new NetSNMP::agent('Name'=>'my_agent_name','AgentX' => 1);
$subagent = 1;
print "Starting subagent\n";
}
print "Registering agent\n";
$agent->register("my_agent_name", $regoid, \&myhandler);
print "Agent registered\n";
if ($subagent) {
$SIG{'INT'} = \&shut_it_down;
$SIG{'QUIT'} = \&shut_it_down;
$running = 1;
while ($running) {
$agent->agent_check_and_process(1);
}
$agent->shutdown();
}
}
sub shut_it_down() {
$running = 0;
print "Shutting down agent\n";
}当我运行代理时,我得到以下信息:
Running new agent
Starting subagent!
Registering agent with oid idb
Agent registered所以我知道很多东西都起作用了。但是,当我运行以下命令时:
snmpget -v 1 -c mycommunity localhost:161 test2.0我收到以下错误消息:
Error in packet
Reason: (noSuchName) There is no such variable name in this MIB.
Failed object: IDB-MIB::test2.0我从snmptranslate了解到mib文件是正确设置的。我甚至查看了snmpget的调试过程(使用-DALL),以确保mib被正确加载和解析。
因此,我的问题是:为什么我的子代理不被传递请求?
更新:
@EhevuTov告诉我,我的MIB文件无效,但是smilint没有报告任何问题,运行snmpget -v 2c -c mycommunity localhost:161 .1.3.6.1.4.1.42134.3.0确实正确地报告了对象的名称(IDB::test2.0),但没有找到任何数据。
我得到了IDB-MIB::test2 = No Such Object available on this agent at this OID,这使我认为我的代理没有正确注册,但是它没有抛出任何错误。
更新2:
我一直在摆弄代理代码。基于CPAN文档(http://metacpan.org/pod/NetSNMP::agent),如果成功的话,$agent->register函数调用应该返回0。因此,我检查了返回代码,得到了以下信息:
Agent registered. Result: NetSNMP::agent::netsnmp_handler_registration=SCALAR(0x201e688)使用Data::Dumper打印出来的结果如下:
$VAR1 = bless( do{\(my $o = 34434624)}, 'NetSNMP::agent::netsnmp_handler_registration' );我模糊地理解祝福的作用,但即使如此,我也不知道这个结果意味着什么。所以我开始认为那个特工是错的。有人知道如何调试这些代理吗?有什么地方可以让我看看它是否被正确地装进了主程序snmpd?
发布于 2013-08-13 17:43:33
我已经解决了问题。这不是MIB的事,而是经纪人的事(我一直认为这件事很好,所以我从来没有费心去检查)。
我一直在独立运行代理,因为它似乎运行得很好(注册处理程序时从未抛出任何错误)。显然,它需要由snmpd直接运行。
我将它移到snmpd可以访问的目录(因为很明显snmpd不能从/root运行脚本,即使它以root的形式运行),并在snmpd.conf中添加了以下几行:
perl print "\nRunning agents now\n";
perl do "/usr/share/snmp/agent.pl" || print "Problem running agent script: $!\n";
perl print "Agents run\n";请注意,这两行已经存在:
disablePerl false
perlInitFile /usr/share/snmp/snmp_perl.pl现在我可以运行snmpget命令并获得预期的响应。
> snmpget -v 2c -c mycommunity localhost:161 .1.3.6.1.4.1.42134.3
IDB-MIB::test2 = INTEGER: 2 testshttps://stackoverflow.com/questions/18137637
复制相似问题