snmp4j的使用
一.什么是snmp及snmp4j?
snmp是 Simple Network Management Protocol (简单网络管理协议)的简写。
SNMP4J是一个用Java来实现SNMP(简单网络管理协议)协议的开源项目.它支持以命令行的形式进行管理与响应。SNMP4J是纯面向对象设计与SNMP++(用C++实现SNMPv1/v2c/v3)相类似。
二.步骤:
管理端步骤:
1.设定传输协议
2.snmp初始化
3.构造发送报文
4.构造发送目标
5.构造响应监听(异步)
6.发送
监控端步骤:
1.设定传输协议
2.snmp初始化
3.构造发送报文
4.构造发送目标
5.发送并返回响应
6.处理返回结果
三.snmp常用的类:
import org.snmp4j.CommunityTarget;
import org.snmp4j.PDU;
import org.snmp4j.Snmp;
import org.snmp4j.TransportMapping;
import org.snmp4j.event.ResponseEvent;
import org.snmp4j.mp.SnmpConstants;
import org.snmp4j.smi.Address;
import org.snmp4j.smi.GenericAddress;
import org.snmp4j.smi.OID;
import org.snmp4j.smi.OctetString;
import org.snmp4j.smi.VariableBinding;
import org.snmp4j.transport.DefaultUdpTransportMapping;
别看这么多包就吓怕了,遇事不惊才是站到最后的人,下面我们一起来研究他们的用法,按照如上步骤:
我就以管理端的方式讲解:
工具的重要性不说大家都懂的,能事半功倍的效果:建议大家先下载snmp4j api文档。然后跟着我一起研究:
首先我们把一个大问题划分成几个小问题,个个击破,于是一个大问题就解决了:(参考下面的demo熟悉snmp协议及snmp4j)
1.设定传输协议:
TransportMapping接口:此该接口代表了SNMP4J所使用的传输层协议。这也是SNMP4J一大特色的地方。按照RFC的规定,SNMP是只使用UDP作为传输层协议的。而SNMP4J支持管理端和代理端使用UDP或者TCP进行传输。该接口有两个子接口。(查看api文档)
在Package org.snmp4j.transport这个包下有一个类设定了传输方式为udp:这个类就是DefaultUdpTransportMapping,使用时只需实例化它即可。
2.初始化snmp:
snmp:这个类主要用来收发数据,它主要有一个send方法,这个很重要,有很多重载。查看文档。
3.构造报文(PDU):
PDU:就是要通信的数据。
4.构造目标:
CommunityTarget:要发送通信数据要去的目标。
5.监听:
ResponseListener:负责监听并回调对应的函数处理。
ResponseListener listener = new ResponseListener() {
public void onResponse(ResponseEvent event) {
((Snmp) event.getSource()).cancel(event.getRequest(), this);
PDU request = event.getRequest();
PDU response = event.getResponse();
if (response != null) {
System.out.println("request.size()=" + request.size());
System.out.println("response.size()=" + response.size());
}
}
};
6.发送:
发送:就是指将pdu(数据)发送到target(目标)机器,监听返回的数据并作响应。
snmp.send(pdu, target, null, listener);
snmp、pdu及target之间的关系可以用一句话概括:
Target就是你远方的恋人,PDU就是你们之间传递的情书、而Snmp就是负责帮你寄信收信的邮差。
四.demo:(以广播的方式)
1.管理端:
1 package com.main;
2
3 import java.io.IOException;
4
5 import org.snmp4j.CommunityTarget;
6 import org.snmp4j.PDU;
7 import org.snmp4j.Snmp;
8 import org.snmp4j.TransportMapping;
9 import org.snmp4j.event.ResponseEvent;
10 import org.snmp4j.event.ResponseListener;
11 import org.snmp4j.mp.SnmpConstants;
12 import org.snmp4j.smi.Address;
13 import org.snmp4j.smi.GenericAddress;
14 import org.snmp4j.smi.OID;
15 import org.snmp4j.smi.OctetString;
16 import org.snmp4j.smi.VariableBinding;
17 import org.snmp4j.transport.DefaultUdpTransportMapping;
18
19
20 /**
21 *以廣播的方式發送snmp并獲取設備的信息
22 *
23 * @author PC
24 *
25 */
26 public class Manager {
27
28 /**
29 * @param args
30 */
31 public static void main(String[] args) {
32 // TODO Auto-generated method stub
33
34 System.out.println("管理端启动。。。");
35
36 send();
37
38 System.out.println("success");
39 }
40
41 // 发送数据到目标机器
42 public static void send() {
43
44 TransportMapping transport = null;
45
46 try {
47 // 传输协议为UDP
48 transport = new DefaultUdpTransportMapping();
49 } catch (IOException e) {
50 // TODO Auto-generated catch block
51 e.printStackTrace();
52 }
53 // 创建snmp对象,发送报文
54 Snmp snmp = new Snmp(transport);
55
56 try {
57 snmp.listen();
58 } catch (IOException e1) {
59 // TODO Auto-generated catch block
60 e1.printStackTrace();
61 }
62
63 OID oid = new OID("1.3.6.1.2.2.1.0");
64 // 报文
65 PDU pdu = new PDU();
66 VariableBinding variableBinding = new VariableBinding(oid);
67 pdu.add(variableBinding);
68 pdu.setType(PDU.GET);
69
70 // 目标
71 CommunityTarget target = new CommunityTarget();
72
73 // 设置snmp共同体
74 OctetString oct = new OctetString("public");
75 target.setCommunity(oct);
76
77 // 向255.255.255.255发送UPD数据包即为UDP广播,接收端只需绑定UDP广播的端口号即可得到数据
78 Address address = GenericAddress.parse("udp:192.168.0.254/161");
79 target.setAddress(address);
80 target.setRetries(2);
81 target.setTimeout(5000);
82 target.setVersion(SnmpConstants.version1);
83
84 // 设置监听对象
85 ResponseListener listener = new ResponseListener() {
86 public void onResponse(ResponseEvent event) {
87 ((Snmp) event.getSource()).cancel(event.getRequest(), this);
88 PDU request = event.getRequest();
89 PDU response = event.getResponse();
90 if (response != null) {
91 System.out.println("request.size()=" + request.size());
92 System.out.println("response.size()=" + response.size());
93 }
94 }
95 };
96
97 try {
98 snmp.send(pdu, target, null, listener);
99 } catch (IOException e) {
100 // TODO Auto-generated catch block
101 e.printStackTrace();
102 }
103 }
104
105 }
2.监控端:(获取本地信息)
1 package com.main;
2
3 import java.io.IOException;
4
5 import org.snmp4j.CommunityTarget;
6 import org.snmp4j.PDU;
7 import org.snmp4j.Snmp;
8 import org.snmp4j.TransportMapping;
9 import org.snmp4j.event.ResponseEvent;
10 import org.snmp4j.mp.SnmpConstants;
11 import org.snmp4j.smi.Address;
12 import org.snmp4j.smi.GenericAddress;
13 import org.snmp4j.smi.OID;
14 import org.snmp4j.smi.OctetString;
15 import org.snmp4j.smi.VariableBinding;
16 import org.snmp4j.transport.DefaultUdpTransportMapping;
17
18 public class Monitor {
19
20 // systemDescr
21 static final String OID1 = "1.3.6.1.2.1.1.1.0";
22 // eth0
23 static final String OID2 = "1.3.6.1.2.1.2.2.1.2.2";
24 // MAC
25 static final String OID3 = "1.3.6.1.2.1.2.2.1.6.2";
26
27 static final String OID4 = "1.3.6.1.2.1.1.1";
28
29 //static final int [] OID5 = {1,3,6,1,2,1,1,2}; 与第一个一样
30
31 /**
32 * @param args
33 */
34 public static void main(String[] args) {
35 // TODO Auto-generated method stub
36 GetOID();
37 }
38
39 /**
40 * 获得本机oid
41 */
42 public static void GetOID() {
43
44 TransportMapping transport = null;
45
46 try {
47 // 传输协议udp
48 transport = new DefaultUdpTransportMapping();
49 transport.listen();
50 } catch (IOException e1) {
51 // TODO Auto-generated catch block
52 e1.printStackTrace();
53 }
54
55 // 構造報文
56 PDU request = new PDU();
57 request.add(new VariableBinding(new OID(OID1)));
58 request.add(new VariableBinding(new OID(OID2)));
59 request.add(new VariableBinding(new OID(OID3)));
60
61 request.add(new VariableBinding(new OID(OID4)));
62 //request.add(new VariableBinding(new OID(OID5)));
63
64 request.setType(PDU.GETNEXT);
65
66 // snmp初始化
67 Snmp snmp = new Snmp(transport);
68
69 // 構造目標
70 CommunityTarget target = new CommunityTarget();
71 Address localAddress =GenericAddress.parse("udp:localhost/161");
72 target.setAddress(localAddress);
73 OctetString oct = new OctetString("public");
74 target.setCommunity(oct);
75 target.setVersion(SnmpConstants.version2c);
76 target.setRetries(2);
77 target.setTimeout(5 * 60);
78
79 try {
80 // 發送報文
81 ResponseEvent responseEvent = snmp.send(request, target);
82
83 PDU response = responseEvent.getResponse();
84 if (response != null) {
85 System.out.println("request.size()=" + request.size());
86 System.out.println("response.size()=" + response.size());
87 VariableBinding vb1 = response.get(0);
88 VariableBinding vb2 = response.get(1);
89 VariableBinding vb3 = response.get(2);
90 VariableBinding vb4 = response.get(3);
91 //VariableBinding vb5 = response.get(4);
92 System.out.println(vb1);
93 System.out.println(vb2);
94 System.out.println(vb3);
95 System.out.println(vb4);
96 //System.out.println(vb5);
97
98 //释放
99 transport.close();
100 }
101 } catch (IOException e) {
102 // TODO Auto-generated catch block
103 e.printStackTrace();
104 }
105 }
106 }
五.MIB:
常用OID:
系统参数(1.3.6.1.2.1.1) | |||
OID | 描述 | 备注 | 请求方式 |
.1.3.6.1.2.1.1.1.0 | 获取系统基本信息 | SysDesc | GET |
.1.3.6.1.2.1.1.3.0 | 监控时间 | sysUptime | GET |
.1.3.6.1.2.1.1.4.0 | 系统联系人 | sysContact | GET |
.1.3.6.1.2.1.1.5.0 | 获取机器名 | SysName | GET |
.1.3.6.1.2.1.1.6.0 | 机器坐在位置 | SysLocation | GET |
.1.3.6.1.2.1.1.7.0 | 机器提供的服务 | SysService | GET |
.1.3.6.1.2.1.25.4.2.1.2 | 系统运行的进程列表 | hrSWRunName | WALK |
.1.3.6.1.2.1.25.6.3.1.2 | 系统安装的软件列表 | hrSWInstalledName | WALK |
网络接口(1.3.6.1.2.1.2) | |||
OID | 描述 | 备注 | 请求方式 |
.1.3.6.1.2.1.2.1.0 | 网络接口的数目 | IfNumber | GET |
.1.3.6.1.2.1.2.2.1.2 | 网络接口信息描述 | IfDescr | WALK |
.1.3.6.1.2.1.2.2.1.3 | 网络接口类型 | IfType | WALK |
.1.3.6.1.2.1.2.2.1.4 | 接口发送和接收的最大IP数据报[BYTE] | IfMTU | WALK |
.1.3.6.1.2.1.2.2.1.5 | 接口当前带宽[bps] | IfSpeed | WALK |
.1.3.6.1.2.1.2.2.1.6 | 接口的物理地址 | IfPhysAddress | WALK |
.1.3.6.1.2.1.2.2.1.8 | 接口当前操作状态[up|down] | IfOperStatus | WALK |
.1.3.6.1.2.1.2.2.1.10 | 接口收到的字节数 | IfInOctet | WALK |
.1.3.6.1.2.1.2.2.1.16 | 接口发送的字节数 | IfOutOctet | WALK |
.1.3.6.1.2.1.2.2.1.11 | 接口收到的数据包个数 | IfInUcastPkts | WALK |
.1.3.6.1.2.1.2.2.1.17 | 接口发送的数据包个数 | IfOutUcastPkts | WALK |
CPU及负载 | |||
OID | 描述 | 备注 | 请求方式 |
. 1.3.6.1.4.1.2021.11.9.0 | 用户CPU百分比 | ssCpuUser | GET |
. 1.3.6.1.4.1.2021.11.10.0 | 系统CPU百分比 | ssCpuSystem | GET |
. 1.3.6.1.4.1.2021.11.11.0 | 空闲CPU百分比 | ssCpuIdle | GET |
. 1.3.6.1.4.1.2021.11.50.0 | 原始用户CPU使用时间 | ssCpuRawUser | GET |
.1.3.6.1.4.1.2021.11.51.0 | 原始nice占用时间 | ssCpuRawNice | GET |
. 1.3.6.1.4.1.2021.11.52.0 | 原始系统CPU使用时间 | ssCpuRawSystem. | GET |
. 1.3.6.1.4.1.2021.11.53.0 | 原始CPU空闲时间 | ssCpuRawIdle | GET |
. 1.3.6.1.2.1.25.3.3.1.2 | CPU的当前负载,N个核就有N个负载 | hrProcessorLoad | WALK |
. 1.3.6.1.4.1.2021.11.3.0 | ssSwapIn | GET | |
. 1.3.6.1.4.1.2021.11.4.0 | SsSwapOut | GET | |
. 1.3.6.1.4.1.2021.11.5.0 | ssIOSent | GET | |
. 1.3.6.1.4.1.2021.11.6.0 | ssIOReceive | GET | |
. 1.3.6.1.4.1.2021.11.7.0 | ssSysInterrupts | GET | |
. 1.3.6.1.4.1.2021.11.8.0 | ssSysContext | GET | |
. 1.3.6.1.4.1.2021.11.54.0 | ssCpuRawWait | GET | |
. 1.3.6.1.4.1.2021.11.56.0 | ssCpuRawInterrupt | GET | |
. 1.3.6.1.4.1.2021.11.57.0 | ssIORawSent | GET | |
. 1.3.6.1.4.1.2021.11.58.0 | ssIORawReceived | GET | |
. 1.3.6.1.4.1.2021.11.59.0 | ssRawInterrupts | GET | |
. 1.3.6.1.4.1.2021.11.60.0 | ssRawContexts | GET | |
. 1.3.6.1.4.1.2021.11.61.0 | ssCpuRawSoftIRQ | GET | |
. 1.3.6.1.4.1.2021.11.62.0 | ssRawSwapIn. | GET | |
. 1.3.6.1.4.1.2021.11.63.0 | ssRawSwapOut | GET | |
.1.3.6.1.4.1.2021.10.1.3.1 | Load5 | GET | |
.1.3.6.1.4.1.2021.10.1.3.2 | Load10 | GET | |
.1.3.6.1.4.1.2021.10.1.3.3 | Load15 | GET |
内存及磁盘(1.3.6.1.2.1.25) | |||
OID | 描述 | 备注 | 请求方式 |
.1.3.6.1.2.1.25.2.2.0 | 获取内存大小 | hrMemorySize | GET |
.1.3.6.1.2.1.25.2.3.1.1 | 存储设备编号 | hrStorageIndex | WALK |
.1.3.6.1.2.1.25.2.3.1.2 | 存储设备类型 | hrStorageType[OID] | WALK |
.1.3.6.1.2.1.25.2.3.1.3 | 存储设备描述 | hrStorageDescr | WALK |
.1.3.6.1.2.1.25.2.3.1.4 | 簇的大小 | hrStorageAllocationUnits | WALK |
.1.3.6.1.2.1.25.2.3.1.5 | 簇的的数目 | hrStorageSize | WALK |
.1.3.6.1.2.1.25.2.3.1.6 | 使用多少,跟总容量相除就是占用率 | hrStorageUsed | WALK |
.1.3.6.1.4.1.2021.4.3.0 | Total Swap Size(虚拟内存) | memTotalSwap | GET |
.1.3.6.1.4.1.2021.4.4.0 | Available Swap Space | memAvailSwap | GET |
.1.3.6.1.4.1.2021.4.5.0 | Total RAM in machine | memTotalReal | GET |
.1.3.6.1.4.1.2021.4.6.0 | Total RAM used | memAvailReal | GET |
.1.3.6.1.4.1.2021.4.11.0 | Total RAM Free | memTotalFree | GET |
.1.3.6.1.4.1.2021.4.13.0 | Total RAM Shared | memShared | GET |
.1.3.6.1.4.1.2021.4.14.0 | Total RAM Buffered | memBuffer | GET |
.1.3.6.1.4.1.2021.4.15.0 | Total Cached Memory | memCached | GET |
.1.3.6.1.4.1.2021.9.1.2 | Path where the disk is mounted | dskPath | WALK |
.1.3.6.1.4.1.2021.9.1.3 | Path of the device for the partition | dskDevice | WALK |
.1.3.6.1.4.1.2021.9.1.6 | Total size of the disk/partion (kBytes) | dskTotal | WALK |
.1.3.6.1.4.1.2021.9.1.7 | Available space on the disk | dskAvail | WALK |
.1.3.6.1.4.1.2021.9.1.8 | Used space on the disk | dskUsed | WALK |
.1.3.6.1.4.1.2021.9.1.9 | Percentage of space used on disk | dskPercent | WALK |
.1.3.6.1.4.1.2021.9.1.10 | Percentage of inodes used on disk | dskPercentNode | WALK |
其他的mib
学习就是学习别人的思维,学习别人遇到问题的处理方法。
------------思路之重
为了明天能幸福,今天付出再多也不后悔。