Chinaunix

标题: 菜鸟向大家请教一个SNMP执行脚本的问题 [打印本页]

作者: happyfishyx    时间: 2015-09-11 17:00
标题: 菜鸟向大家请教一个SNMP执行脚本的问题
我想通过CACTI抓一台服务器的实时DNS请求,写了一个脚本如下:

脚本文件 query.sh :
  1. #! /bin/sh

  2. time=$(date +%H:%M:);

  3. counters=$(grep  $time.*AAAA /var/named/data/query.log |wc -l);

  4. echo $counters;
复制代码
该脚本直接执行没有问题,可以正常显示数据。


在SNMP配置文件snmpd.conf中添加自定义OID的行:
  1. extend .1.3.6.1.4.1.2021.1500 queryDNSRequest  /usr/shell_script/query.sh
复制代码
通过snmpwalk采集该OID的信息,就出问题。

直接运行脚本:




snmp调用:




但是如果修改脚本,将echo 的内容从变量counters改为固定值8888,再调snmp,则能正常输出8888:




另外,不知道SNMP采集的字段中为什么会有 16进制代码

不知道到底哪里出了问题,请给位指教!
作者: klainogn    时间: 2015-09-13 17:52
可能的问题是: 变量中有一些特殊字符, 所以最好把变量带上双引号
对于采集数据中有十六进制并不奇怪,如果返回节点值的类型是hexstring的话,工具是应该按十六进制展示出来的

snmp报文中节点是这样定义的: oid+valuetype+value
作者: chenxiao2233    时间: 2015-09-13 19:43
注意观察第二个返回hexstring的oid的最后一个数据为30 对应的10进制数据为48.我觉得数据已经返回了 。 返回这样的oid数据也是第一次见,可能由于net-snmp版本不同还是其他原因,多看看 总能解决的,搞懂16进制返回的是什么
作者: happyfishyx    时间: 2015-09-17 10:05
好奇怪,还是没解决,我怀疑是脚本中
  1. counters=$(grep  $time.*AAAA /var/named/data/query.log |wc -l);
复制代码
这一行没有正确执行。
因为我如果在后面给counters赋一个固定值,就能正常打印这个数值了。
作者: happyfishyx    时间: 2015-09-17 11:57
我发现那几行16进制可能是个报错信息,我用在线工具转成字符串,就是这个:

grep: /var/named/data/query.log: 权限不够


后面是乱码,前面刚好是我那个脚本要读取的日志文件。

我猜测会不会是权限问题,就去把日志文件包括上级目录都改成777权限了,但是还是不行……




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2