免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3674 | 回复: 4
打印 上一主题 下一主题

[系统管理] 菜鸟向大家请教一个SNMP执行脚本的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-09-11 17:00 |只看该作者 |倒序浏览
我想通过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进制代码

不知道到底哪里出了问题,请给位指教!

论坛徽章:
5
白羊座
日期:2014-10-28 11:23:27水瓶座
日期:2015-01-20 10:19:022015亚冠之柏斯波利斯
日期:2015-07-11 18:17:2015-16赛季CBA联赛之同曦
日期:2015-12-23 12:38:582016猴年福章徽章
日期:2016-02-18 15:30:34
2 [报告]
发表于 2015-09-13 17:52 |只看该作者
可能的问题是: 变量中有一些特殊字符, 所以最好把变量带上双引号
对于采集数据中有十六进制并不奇怪,如果返回节点值的类型是hexstring的话,工具是应该按十六进制展示出来的

snmp报文中节点是这样定义的: oid+valuetype+value

论坛徽章:
0
3 [报告]
发表于 2015-09-13 19:43 |只看该作者
注意观察第二个返回hexstring的oid的最后一个数据为30 对应的10进制数据为48.我觉得数据已经返回了 。 返回这样的oid数据也是第一次见,可能由于net-snmp版本不同还是其他原因,多看看 总能解决的,搞懂16进制返回的是什么

论坛徽章:
0
4 [报告]
发表于 2015-09-17 10:05 |只看该作者
好奇怪,还是没解决,我怀疑是脚本中
  1. counters=$(grep  $time.*AAAA /var/named/data/query.log |wc -l);
复制代码
这一行没有正确执行。
因为我如果在后面给counters赋一个固定值,就能正常打印这个数值了。

论坛徽章:
0
5 [报告]
发表于 2015-09-17 11:57 |只看该作者
我发现那几行16进制可能是个报错信息,我用在线工具转成字符串,就是这个:

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


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

我猜测会不会是权限问题,就去把日志文件包括上级目录都改成777权限了,但是还是不行……
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP