我想通过 SNMP 监控几个服务的状态。
手册页上说:
proc NAME [MAX [MIN]] monitors the number of processes called NAME (as reported by "/bin/ps -e") running on the local system.
因此我添加了以下几行/etc/snmp/snmpd.conf
:
proc smbd
proc nfsd
但相应的 OID 仍然返回零:
iso.3.6.1.4.1.2021.2.1.100.4 = INTEGER: 0
iso.3.6.1.4.1.2021.2.1.100.5 = INTEGER: 0
尽管ps -e
显示smbd
和nfsd
流程如下:
> ps -e | grep "smbd\|nfsd"
8267 ? 00:00:01 smbd
10179 ? 00:00:04 smbd
11068 ? 00:00:00 nfsd4_callbacks
11072 ? 00:12:53 nfsd
11073 ? 00:13:33 nfsd
11074 ? 00:14:35 nfsd
11075 ? 00:16:23 nfsd
11076 ? 00:21:52 nfsd
11077 ? 00:33:34 nfsd
11078 ? 00:48:10 nfsd
11079 ? 01:02:44 nfsd
15135 ? 00:00:03 smbd
15137 ? 00:00:17 smbd
15141 ? 00:00:05 smbd
20603 ? 00:00:00 smbd
我还能够获取具有 OID 的正在运行的进程列表,1.3.6.1.2.1.25.4.2.1.2
其中还包含smbd
进程nfsd
:
> snmpwalk -v 2c -c secret host 1.3.6.1.2.1.25.4.2.1.2 | grep "smbd\|nfsd"
iso.3.6.1.2.1.25.4.2.1.2.11068 = STRING: "nfsd4_callbacks"
iso.3.6.1.2.1.25.4.2.1.2.11072 = STRING: "nfsd"
iso.3.6.1.2.1.25.4.2.1.2.11073 = STRING: "nfsd"
iso.3.6.1.2.1.25.4.2.1.2.11074 = STRING: "nfsd"
iso.3.6.1.2.1.25.4.2.1.2.11075 = STRING: "nfsd"
iso.3.6.1.2.1.25.4.2.1.2.11076 = STRING: "nfsd"
iso.3.6.1.2.1.25.4.2.1.2.11077 = STRING: "nfsd"
iso.3.6.1.2.1.25.4.2.1.2.11078 = STRING: "nfsd"
iso.3.6.1.2.1.25.4.2.1.2.11079 = STRING: "nfsd"
iso.3.6.1.2.1.25.4.2.1.2.11724 = STRING: "smbd"
iso.3.6.1.2.1.25.4.2.1.2.12367 = STRING: "smbd"
iso.3.6.1.2.1.25.4.2.1.2.15135 = STRING: "smbd"
iso.3.6.1.2.1.25.4.2.1.2.15137 = STRING: "smbd"
iso.3.6.1.2.1.25.4.2.1.2.15141 = STRING: "smbd"
iso.3.6.1.2.1.25.4.2.1.2.29897 = STRING: "smbd"
它应该像这样工作吗?使用proc
SNMP 指令监控服务是一个好主意吗?还是我应该使用extend
s(已经让它们为 ZFS 和 SLURM 状态工作)?
环境:
- NET-SNMP 5.7.3
- Ubuntu 服务器 16.04
答案1
下面的 OID 中报告的零1.3.6.1.4.1.2021.2.1.100
实际上意味着一切正常,非零则表示出现错误。
供将来参考:1.3.6.1.4.1.2021.2.1.101
如果出现错误,下面的 OID 会提供更多信息。