我在通过 snmpwalk 命令运行脚本时遇到问题,该命令应将随机数重定向到输出文件中:
我已在 snmpd.conf undet/etc/snmp/中为脚本配置了 OID 作为 执行.1.3.6.1.4.1.99.1.53.1006 script.sh.sh/root/my_folder/script.sh
<小时/>我的脚本如下:
#!/usr/bin/ksh
Out_Path="$HOME/output.txt"
echo $RANDOM >> $Out_Path
--------------------------
现在我正在执行 snmpwalk 命令: snmpwalk -t 10 -v 1 -c 公共(public) 127.0.0.1.1.3.6.1.4.1.99.1.53.1006 在输出文件中我得到 2 个随机数而不是 1。 我期望output.txt 文件中应该只存在一个随机数。 任何人都可以解释这种行为或某种解决方案吗?
<小时/>实际问题:
我正在解释我想要实现的目标。我需要通过 snmpget 命令执行脚本。
问题 1:当我使用 SNMPGET 命令时,脚本执行并响应(内部),我已满(超过 1 KB),但将此响应保存在文件中后,我在 while 循环中执行 echo $line ,这将获取文件的行,并且按照我的期望,它应该向我显示整个数据。(但我只能获取 1 KB 数据)
问题2:为了解决问题1,我采用了一种新设计,就像从1个OID(脚本)开始,我在一个文件中获取了全部数据。之后,我使用新的OID执行一个新脚本,它将获取1条记录(1KB)并修改现有数据并更新数据。所以像这样,我将使用具有不同OID的snmpwalk多次执行第二个脚本,这样我将获得所有记录。但我的问题是,当我尝试更新记录(文件)时,然后在一次执行中它正在删除2 KB 数据,因此我发布了这个问题。(1 snmpwalk 命令中的 2 倍随机数)。
我希望您现在了解问题,但如果您想要更多详细信息,我会向您解释。
最佳答案
snmpwalk 命令由 snmpgetnext 命令组成,只要子树中存在要返回的内容,就会重复执行该命令。我想在这种情况下,在单个 snmpwalk 调用后面发送两个 getnext 请求,以确定没有更多数据可供检索。可以肯定的是,请使用 tcpdump 或某些wireshark 解决方案嗅探流量。顺便提一句。您确定 -t10 是正确的超时吗?我会将显式重复选项设置为 0 以避免重传(-r0 选项)。
您想要做的是对上面提到的 OID 执行 snmp get/getnext 请求来执行脚本并将其输出作为 SNMP 响应返回。我认为 1 KB 问题是由其他原因引起的 - 它似乎不是构建大响应时的 SNMP 代理问题。请尝试以下 SNMPv1 命令(如果您也有 SNMPv3 访问权限,请告诉我):
snmpget -v1 -t25 -r0 -cprivate <IP> .1.3.6.1.4.1.99.1.53.1006
或
snmpgetnext -v1 -t25 -r0 -cprivate <IP> .1.3.6.1.4.1.99.1.53.1005
请注意 snmpgetnext 请求的 OID 末尾的 1005 个八位字节。这样的OID可能不存在,getnext应该正确访问1006,因为它是第一个,存在的OID在1005之后。
关于linux - 从 shell 脚本获取随机数并使用 snmpcommad(SNMP 协议(protocol))将其存储到文件中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13836558/