http://www.blogjava.net/fjzag/articles/317773.html

ubuntu@ubuntu-vm:/work/sv-g5-application/projects/sysmonitor/src$ cat SVPSysMonitor.cpp
/*################################################################################################## Company : Huizhou Desay SV Automotive Co., Ltd. Division : Automotive Electronics, Desay Corporation Business Unit : Central Technology Department : Advanced Development (Huizhou) Project : G5 Platform Module : System Monitor Create Date : Nov 03, 2016 - Liu Chuqun <Chuqun.Liu@desay-svautomotive.com> Update Date : ##################################################################################################*/ #include "SVPType.h"
#include "SVPTime.h"
#include "SVPLog.h" #ifdef SVP_LOG_TAG
#undef SVP_LOG_TAG
#endif
#define SVP_LOG_TAG "sysmonitor" #define NAME_LEN 64
#define BUFFER_LEN 1024 static SVPChar g_name[NAME_LEN] = { };
static SVPChar g_buffer[BUFFER_LEN] = { };
static SVPInt32 g_cpuPercent = ;
static SVPInt32 g_memPercent = ;
static SVPInt32 g_memTotal = ;
static SVPInt32 g_memFree = ;
static SVPInt32 g_memAvailable = ;
static SVPInt32 g_topCPU = ;
static SVPInt32 g_topMemUse = ; void GetCPUInfo();
void GetMemInfo();
void PrintInfo();
void MonitorStrategy();
SVPVoid ResetSystem(); SVPInt32 main(SVPInt32 argc, SVPChar* argv[])
{
while()
{
GetCPUInfo();
GetMemInfo();
PrintInfo();
MonitorStrategy();
sleep();
} return ;
} void MonitorStrategy()
{
SVPUlong ulCurStrategyTickCount = SVPTime::GetTickCount();
if (ulCurStrategyTickCount <= )
return;// 开机30秒内不执行策略。 static SVPBool s_bInLimitMode = SVP_FALSE;
static SVPUlong s_ulEnterLimitModeTime = ;
static SVPUlong s_ulLimitModeCheckCount = ;
if (g_cpuPercent >= )
{
++s_ulLimitModeCheckCount;
if (SVP_FALSE == s_bInLimitMode)
{
s_bInLimitMode = SVP_TRUE;
s_ulEnterLimitModeTime = ulCurStrategyTickCount;
} if (ulCurStrategyTickCount - s_ulEnterLimitModeTime >= )
{
SVP_INFO("s_ulLimitModeCheckCount[%lu]", s_ulLimitModeCheckCount);
if (s_ulLimitModeCheckCount >= )
ResetSystem();
}
}
else
{
s_bInLimitMode = SVP_FALSE;
s_ulLimitModeCheckCount = ;
}
} void PrintInfo()
{
SVP_INFO("[TopMem:%3d%%, TopCPU:%3d%%] MemTotal:%dKB, MemAvailable:%dKB, MEM:%3d%%, CPU:%3d%%.", g_topMemUse, g_topCPU, g_memTotal, g_memAvailable, g_memPercent, g_cpuPercent);
static SVPInt32 printCount = ;
++printCount;
if (printCount >= )
{
printCount = ;
system("ps");
usleep();
system("top -n1;ls /media");
}
} void GetCPUInfo()
{//获取cpu占用率
FILE *fp = fopen("/proc/stat", "r");
if (fp)
{
memset(g_name, , NAME_LEN);
memset(g_buffer, , BUFFER_LEN);
static SVPInt32 idle0 = , total0 = ;
SVPInt32 user1, nice, sys, idle1, iowait, irq, softirq, total1 = ; fgets(g_buffer, sizeof(g_buffer), fp);
sscanf(g_buffer, "%s %d %d %d %d %d %d %d", g_name, &user1, &nice, &sys,
&idle1, &iowait, &irq, &softirq); total1 = user1 + nice + sys + iowait + irq + softirq + idle1;
if (total1 != total0)
g_cpuPercent = - ( ((idle1 - idle0) * )/ (double) (total1 - total0) );
else
SVP_WARN("cpu total is the same. /proc/stat maybe error!"); idle0 = idle1;
total0 = total1; if (g_cpuPercent > g_topCPU)
g_topCPU = g_cpuPercent; fclose(fp);
}
else
{
SVP_ERROR("fopen /proc/stat failed:%s", strerror(errno));
}
} void GetMemInfo()
{//获取内存信息
FILE *fp = fopen("/proc/meminfo", "r");
if (fp)
{
memset(g_name, , NAME_LEN);
memset(g_buffer, , BUFFER_LEN);
SVPChar unit[] = { };
fgets(g_buffer, sizeof(g_buffer), fp);
sscanf(g_buffer, "%s %d %s", g_name, &g_memTotal, unit); fgets(g_buffer, sizeof(g_buffer), fp);
sscanf(g_buffer, "%s %d %s", g_name, &g_memFree, unit); fgets(g_buffer, sizeof(g_buffer), fp);
sscanf(g_buffer, "%s %d %s", g_name, &g_memAvailable, unit); if (g_memTotal)
g_memPercent = - ( * g_memAvailable) / g_memTotal;
else
SVP_WARN("mem total is 0!"); if (g_memPercent > g_topMemUse)
g_topMemUse = g_memPercent; fclose(fp);
}
else
{
SVP_ERROR("fopen /proc/meminfo failed:%s", strerror(errno));
}
} SVPVoid ResetSystem()
{
system("top -n1;ls /media");
SVP_WARN("restart system now ...");
SVPUint8 tryTimes = ;
while(tryTimes < )
{
++tryTimes;
if (- != system("powerctrl 10 &"))
break;
else
SVP_ERROR("reboot system fail!");
sleep();
} //最后一招。
//需要radio软件修改逻辑为:任何时候,只要收到first connect消息,就走core重新启动的逻辑。不要再过滤first connect消息。
sleep();
SVP_ERROR("can't restart system through the spi msg!");
tryTimes = ;
while(tryTimes < )
{
++tryTimes;
if (- != system("reboot -f &"))
break;
else
SVP_ERROR("reboot system fail!");
sleep();
}
}

内存和cpu的更多相关文章

  1. Ambari server:无法显示内存,CPU等使用率

    Ambari server安装完毕后,都能正确显示各种信息.运行了几天后,发现无法显示内存,CPU等信息. 查找日志发现有错误,日志路径:/var/log/ambari-server/ambari-s ...

  2. C#实现对远程服务器的内存和CPU监控

    C#实现对远程服务器的内存和CPU监控小记 1.  主要使用到的组件有System.Management.dll 2.  主要类为 :ManagementScope 连接远程服务器示例代码: priv ...

  3. YARN的内存和CPU配置

    时间 2015-06-05 00:00:00  JavaChen's Blog 原文  http://blog.javachen.com/2015/06/05/yarn-memory-and-cpu- ...

  4. Spark Tungsten揭秘 Day4 内存和CPU优化使用

    Spark Tungsten揭秘 Day4 内存和CPU优化使用 今天聚焦于内存和CPU的优化使用,这是Spark2.0提供的关于执行时的非常大的优化部分. 对过去的代码研究,我们会发现,抽象的提高, ...

  5. 系统内存和CPU管理、监控

    本博文的主要内容有 .系统内存管理.监控:vmstat和free -mt .系统CPU管理.监控:sar -u.mpstat.uptime linux系统内存和CPU是在系统运行的过程中不断消耗的资源 ...

  6. 查看linux/AIX系统内存及CPU占用百分比

    1.linux下查看CPU及内存占用情况 查看内存占用百分比: [root@rusky ~]# free -m | sed -n '2p' | awk '{print "used mem i ...

  7. 转---高并发Web服务的演变——节约系统内存和CPU

    [问底]徐汉彬:高并发Web服务的演变——节约系统内存和CPU 发表于22小时前| 4223次阅读| 来源CSDN| 22 条评论| 作者徐汉彬 问底Web服务内存CPU并发徐汉彬 摘要:现在的Web ...

  8. Chrome 内存和CPU消耗量双料冠军

    今天统计了下某个时刻各进程的内存和CPU使用概况.结果发现,Chrome消耗量真是不一般的大.比Windows主进程都还猛! 另外发现百度安全卫士占用CPU也比较猛. powershell下输入: p ...

  9. 解决持久化数据太大,单个节点的硬盘无法存储的问题;解决运算量太大,单个节点的内存、CPU无法处理的问题

    需要学习的技术很多,要自学新知识也不是一件容易的事,选择一个自己比较感兴趣的会是一个比较好的开端,于是,打算学一学分布式系统. 带着问题,有目的的学习,先了解整体架构,在深入感兴趣的细节,这是我的计划 ...

  10. 【原创】大叔经验分享(21)yarn中查看每个应用实时占用的内存和cpu资源

    在yarn中的application详情页面 http://resourcemanager/cluster/app/$applicationId 或者通过application命令 yarn appl ...

随机推荐

  1. python里pickle模块

    Pickle模块用于将复杂的文件转化为二进制的文件 pickle模块一般是在源代码里面含有较大的字典或者列表等复杂文件时,我们如果将文件直接写在源代码里面,这样会使得代码很冗余,并且源代码文件所占空间 ...

  2. NGUI制作流光效果

    效果展示: 技巧: 1.勾选UIPanel下的Normal启用UI的法线贴图,并建立带有法线贴图的UI对象(此处用NGUI自带的Reflector.Atlas中的图作为UI). 2.建立点光源并为其添 ...

  3. ASP.NET中Gridview一些技巧

    ASP.NET中Gridview一些技巧 一.后台覆盖掉Gridview中自动填充的值 我们可以再Gridview中的事件触发的过程中修改其中的值,而这些值将会在具体的运行过程中覆盖掉那些自动属性.这 ...

  4. 一种跨平台的C++遍历目录的方法

    参考了网络上各路大神的实现方法.主要使用了io.h库 #include <iostream> #include <cstring> #include <io.h> ...

  5. Spark mlib的本地向量

    Spark mlib的本地向量有两种: DenseVctor :稠密向量 其创建方式 Vector.dense(数据) SparseVector :稀疏向量 其创建方式有两种: 方法一:Vector. ...

  6. LeetCode 104——二叉树中的最大深度

    1. 题目 2. 解答 如果根节点为空,直接返回 0.如果根节点非空,递归得到其左右子树的深度,树的深度就为左右子树深度的最大值加 1. /** * Definition for a binary t ...

  7. OpenCV学习5-----使用Mat合并多张图像

    最近做实验需要对比实验结果,需要将几张图片拼在一起,直观对比. 尝试用OpenCV解决. 核心思想其实是   声明一个足够大的,正好容纳下那几张图片的mat,然后将拼图依次copy到大图片相应的位置. ...

  8. JavaScript筑基篇(三)->JS原型和原型链的理解

    删除理由:很久以前写的,当时理解不够深入,这样描述反而看起来更复杂了.因此就删掉,免得误人子弟! 可以看看另一篇文章:[如何继承Date对象?由一道题彻底弄懂JS继承.](http://www.cnb ...

  9. Calculation PartⅡ

    GitHub/object-oriented 误删内容--周末修复

  10. 重新看《JavaScript高级程序设计》

    几点心得: 1)数据是基础,一共有3种基础数据:null.undefined.和object:遵循从无到有从简单到复杂的演变过程 2)衍生数据:衍生数据是指操作符合语句,这些是基础数据产生导致的必然结 ...