Linux 下监控程序 -- 共享内存通讯,消息订阅发布
来源:互联网 发布:idm mac版 知乎 编辑:程序博客网 时间:2024/05/29 15:07
实习的时候写的小练习程序:
VMSTAT.h
此代码用以从服务器获取运行状态信息
class VMSTAT{public: double stat[20]; /* * Proc * * 0:r: The number of processes waiting for run time. * 1:b: The number of processes in uninterruptible sleep. * * Memory * * 2:swpd: the amount of virtual memory used. * 3:free: the amount of idle memory. * 4:buff: the amount of memory used as buffers. * 5:cache: the amount of memory used as cache. * * Swap * * 6:si: Amount of memory swapped in from disk (/s). * 7:Amount of memory swapped to disk (/s). * * IO * * 8:bi: Blocks received from a block device (blocks/s). * 9:bo: Blocks sent to a block device (blocks/s). * * System * * 10:in: The number of interrupts per second, including the clock. * 11:cs: The number of context switches per second. * * CPU * * 12:us: Time spent running non-kernel code. (user time, including nice time) * 13:sy: Time spent running kernel code. (system time) * 14:id: Time spent idle. Prior to Linux 2.5.41, this includes IO-wait time. * 15:wa: Time spent waiting for IO. Prior to Linux 2.5.41, included in idle. * 16:st: Time stolen from a virtual machine. Prior to Linux 2.6.11, unknown. * * Add * * 17:Total Memory * 18:Used Memory * 19:CPU Usage */ void update() { //init array FILE* file = popen("vmstat","r"); char buf[300]; fgets (buf , 300 , file); fgets (buf , 300 , file); fgets (buf , 300 , file); int index=0; for(int i = 0;i<300;i++) { while(buf[i]<'0'||buf[i]>'9') i++; int tmp = 0; while(buf[i]>='0'&&buf[i]<='9') { tmp = tmp*10 + (buf[i]-'0'); i++; } stat[index++] = tmp*1.0; if(index == 17) break; } pclose(file); //total memory file = popen("cat /proc/meminfo","r"); double total=0; fgets (buf , 300 , file); char str[7]; for(int i=17;i<24;i++) str[i-17]=buf[i]; for(int i=0;i<7;i++) { total =total*10+(str[i]==' '?0:(str[i]-'0')); } //calculate all stat[17]=total; stat[18]=total-stat[3]; stat[19]=100-stat[14]; pclose(file); }};
pshm.h
定义共享内存数据结构的结构体
定义主题ID
typedef struct tagMyStat{ int attche_count; int total; int avaliable; int used; int cpu_useage;} MyStat;#define CENTOS_PER (4499) //主题CENTOS_PER 由服务器发布 客户端进行订阅 服务器可发布多个主题,而客户端可以选择其中若干个感兴趣的进行订阅
shmClient.cpp
#include <stdio.h>#include <time.h>#include <stdlib.h>#include <unistd.h>#include <sys/shm.h>#include "VMSTAT.h"#include "pshm.h"int main(){ void *shm = NULL; MyStat *shared = NULL; int shmid = shmget((key_t)CENTOS_PER,sizeof(MyStat),IPC_CREAT); if(shmid == -1) { printf("%s\n","shmget failed!"); return 0; } shm = shmat(shmid, (void*)0, 0); if(shm == (void*)-1) { printf("%s\n","shmat failed!"); } printf("Memory attached at %lx\n", (long)shm); shared = (MyStat*)shm; shared->attche_count ++; time_t rawtime; struct tm * t; while(1) { time ( &rawtime ); t = localtime ( &rawtime ); printf("Client@%d:%d:%d :Total: %d MB Aviliable: %d MB Used: %d MB CPU: %d %\n",t->tm_hour,t->tm_min,t->tm_sec,shared->total,shared->avaliable,shared->used,shared->cpu_useage); sleep(1); } shared->attche_count --; if(shmdt(shm) == -1) { printf("%s\n","shmdt failed!"); } if(shmctl(shmid, IPC_RMID, 0) == -1) { printf("%s\n","shmctl(IPC_RMID) failed!"); } sleep(2); return 0;}
shmServer.cpp
#include <stdio.h>#include <time.h>#include <string.h>#include <stdlib.h>#include <unistd.h>#include <sys/shm.h>#include "VMSTAT.h"#include "pshm.h"int main(){ void *shm = NULL; MyStat *shared = NULL; int shmid = shmget((key_t)CENTOS_PER,sizeof(MyStat),0666|IPC_CREAT); if(shmid == -1) { printf("%s\n","shmget failed!"); return 0; } shm = shmat(shmid, (void*)0, 0); if(shm == (void*)-1) { printf("%s\n","shmat failed!"); } printf("Memory attached at %lx\n", (long)shm); shared = (MyStat*)shm; memset(shared, 0, sizeof(MyStat)); shared->attche_count=0; VMSTAT s; time_t rawtime; struct tm * t; while(1) { s.update(); shared->total = int(s.stat[17]/1000); shared->avaliable = int(s.stat[3]/1000); shared->used = int(s.stat[18]/1000); shared->cpu_useage = int(s.stat[19]); time ( &rawtime ); t = localtime ( &rawtime ); printf("Server@%2d:%2d:%2d (%d):Total: %d MB Aviliable: %d MB Used: %d MB CPU: %d %\n",t->tm_hour,t->tm_min,t->tm_sec,shared->attche_count,shared->total,shared->avaliable,shared->used,shared->cpu_useage); sleep(1); } if(shmdt(shm) == -1) { printf("%s\n","shmdt failed!"); } if(shmctl(shmid, IPC_RMID, 0) == -1) { printf("%s\n","shmctl(IPC_RMID) failed!"); } sleep(2); return 0;}
服务器运行截图:
客户端运行截图:
0 0
- Linux 下监控程序 -- 共享内存通讯,消息订阅发布
- php 实现redis发布订阅消息及时通讯
- ROS下视频消息发布与订阅
- linux进程通讯-共享内存
- linux进程通讯-共享内存
- linux进程通讯-共享内存
- Linux下的内存监控小程序
- 消息通讯和内存共享的问题
- Linux下共享内存简单程序示例
- linux下使用hiredis异步API实现sub/pub消息订阅和发布的功能
- linux下使用hiredis异步API实现sub/pub消息订阅和发布的功能
- Linux进程通讯:管道通讯、信号通讯、共享内存
- Linux--进程间通讯IPC(信号量,消息队列,共享内存)
- 发布-订阅消息模式
- 发布-订阅消息模式
- 发布-订阅消息模式
- 发布-订阅消息模式
- RabbitMQ发布订阅消息
- 出成绩了。。
- Linux线程-互斥锁pthread_mutex_t应用
- deep learning toolbox学习5之SAE
- java异常分类
- Linux 按照时间查找文件
- Linux 下监控程序 -- 共享内存通讯,消息订阅发布
- java线程(2)
- 怎样写网站QQ客服代码
- 登录错误:尝试向URI“http://localhost:61130/UserService.asmx”……跨域策略……解决办法
- 四位科研牛人介绍的文献阅读经验
- 约束延迟
- Linux 设备驱动poll轮询编程
- android开发小问题收集【未完】
- cocos2d_x 问题汇总