书接上文,在上文中进行了对系统时间的提取,在此基础上,可以对OID为.1.3.6.1.2.1.25.5.1.1.2与.1.3.6.1.2.1.25.5.1.1.1的进程内存与CPU使用率的原始数据记性提取。需要注意的是,通过OID提取到的内存信息为该进程的工作设置(内存),相关内容可以通过资源管理器显示,具体区别可以百度。
写了个子函数,在其中定义的内容如下:
Oid full_oid[200];//读取OID一列数据中间存储变量数组
struct Process//获取系统进程名称,PID,路径,t1时刻CPU占用率,t2时刻CPU占用率,内存占用率,进程在t2-t1时刻的CPU占用率
{
char name[50];
char PID[20];
char Path[100];
Oid OID;
int Cpu_used_t1;
int Cpu_used_t2;
int Mem_used;
float Cpu_used_percent_for_each_process;
};
extern int sum_cpu_t1 = 0;//t1时刻CPU总占用率
extern int sum_cpu_t2 = 0;//t2时刻CPU总占用率
代码段如下:
/*===========================================================
函数名称:Get_Per_CPU_Mem
函数功能:获取进程内存占用,将内存占用信息发送到进程信息结构体数组的元素当中
函数参数:const char * aa1:主机地址:监听端口("127.0.0.1:161");
const char * bb1:OID,MIB数据类型,指定为"public"
Process Pro[]:进程信息结构体数组;
返回值: 无返回值
=============================================================*/
void Get_Per_CPU_Mem(const char * aa1, const char * bb1, Process Pro[])
{
Snmp::socket_startup(); //初始化Winsocket套接字
UdpAddress udp(aa1);
CTarget ctarget(udp);
ctarget.set_readcommunity(bb1);
snmp_version version = version2c;
ctarget.set_version(version);
SnmpTarget *target;
target = &ctarget;
int status;
Snmp snmp(status, 0, false); // 创建snmp对象
int i = 0;
int index_count = 0; //该列的行数
bool tag = true; //标志循环是否结束
Pdu pdu;
Vb vb;
Oid oid = "