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. 【Extremely Basic Words for Listening】word list

    [Extremely Basic Words for Listening]word list updated continuously recite count: 0 careless exercis ...

  2. Python 作用域和命名空间

    在介绍类之前,我首先要告诉你一些Python的作用域规则.类定义对命名空间有一些巧妙的技巧,你需要知道作用域和命名空间如何工作才能完全理解正在发生的事情.顺便说一下,关于这个主题的知识对任何高级Pyt ...

  3. lintcode 二分查找

    题目:二分查找 描述:给定一个排序的整数数组(升序)和一个要查找的整数target,用O(logn)的时间查找到target第一次出现的下标(从0开始),如果target不存在于数组中,返回-1. c ...

  4. 利用maven进行项目管理

    下面为maven项目管理的一个结构 首先pom是路径文件,我们在编译或是运行程序时调用到jdk或一些自己写的jar包时会需要指明物理路径,这里的pom是一样的道理,同时在maven的管理下多出来了一些 ...

  5. gitignore 文件生效办法

    .gitignore 可以添加一些不加入git版本控制的文件 比如一些测试文件.因人而异的配置信息等等 .gitignore 文件展示如下 /.idea/target//.classpath /.pr ...

  6. 在页面使用echarts的地图(解决地图不完整)

    测试环境:IDEA+Tomcat7 谷歌浏览器 创建好web工程,编写jsp页面,在自己编写的JSP页面上导包 现在echarts停止了在其网站上下载地图脚本,直接通过src引用网站上的china.j ...

  7. pandas协助工具

    pandas有时候操作很不方便,也有可能是我不熟练吧,反正就是各种别扭.下面是我写的一个简单的json数据操作工具,能够完成简单的数据分析工作,后续会不断完善的 # coding=utf-8 impo ...

  8. metamask注记词

    leaf orbit poet zebra toy day put dinosaur review cool pluck throw(m) 一个钱包地址 里面有多个账号 菲苾代表了不同网络

  9. sql月,年,统计报表sql报表

    select DevName as 设备名称, count(flux) as 流量数据个数, max(flux) as 流量最大值, min(flux) as 流量最小值, avg(flux) as ...

  10. JS原型与面向对象总结

    ECMAScript有两种开发模式:1.函数式(过程化),2.面向对象(OOP).面向对象的语言有一个标志,那就是类的概念,而通过类可以创建任意多个具有相同属性和方法的对象.但 是,ECMAScrip ...