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. Ubuntu卡在logo界面

    对于这个问题,我也是在最近一次偶然的机会中发现的. 我重装了了Ubuntu 18.04, 很多东西需要重新配置,  有个刚性需求就是配置shadowsocks实现***,对于从windows向linu ...

  2. C 数数位 while循环

    #include <stdio.h> int main(int argc, char **argv) { //定义两个变量  x n 把n初始化 int x; int n=0; //输入x ...

  3. js设计模式:工厂模式、构造函数模式、原型模式、混合模式

    一.js面向对象程序 var o1 = new Object();     o1.name = "宾宾";     o1.sex = "男";     o1.a ...

  4. 【Python 开发】第一篇:计算机基础

    一.计算机基础 首先Python是一门编程语言 语言: 那什么是语言? 语言就是一种事物与另一种事物沟通的介质.所以说编程语言是程序员跟计算机沟通的介质. 什么是编程: 准确来说就是程序员用计算机所能 ...

  5. IntelliJ IDEA 2017.3/2018.1/.2 激活

    传统的License Server方式已经无法注册IntelliJ IDEA2017.3的版本了. http://idea.lanyus.com,这个网站有破解补丁和注册码两种方式,另外http:// ...

  6. chameleon-Mini(迷你变色龙)

    Chameleon Mini(迷你变色龙)是一个比一般信用卡稍大的小型开发板,是开源产品. 如图 Chameleon Mini可以完全复制许多商业非接触式智能卡包括UID卡,在内的全部内容,因此可以用 ...

  7. POJ 3487 The Stable Marriage Problem(稳定婚姻问题 模版题)

    Description The stable marriage problem consists of matching members of two different sets according ...

  8. NSValue的valueWithBytes:objCType:方法

    + (NSValue *)valueWithBytes:(const void *)value objCType:(const char *)type; NSValue的valueWithBytes: ...

  9. JavaScript初探系列之日期对象

    时间对象是一个我们经常要用到的对象,无论是做时间输出.时间判断等操作时都与这个对象离不开.它是一个内置对象——而不是其它对象的属性,允许用户执行各种使用日期和时间的过程. 一   Date 日期对象 ...

  10. Coursera:Internet History ,Techornology and Security

    WEEK1 War Time Computing and Communication Bletchley Park 布莱彻利庄园:a top-secret code breaking effort b ...