linux环境 c语言操作mysql 占用cpu高如何解决-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

linux环境 c语言操作mysql 占用cpu高如何解决

在linux下写一个数据库监控程序,用的纯c,操作mysql用的是mysql自带的c API:mysql_init,mysql_real_connect,mysql_query...,定时监控用的是信号量。代码如下:

#include <stdio.h>
#include <time.h>
#include <sys/time.h>
#include <stdlib.h>
#include <signal.h>
 
static int count = 0;
static struct itimerval oldtv;
 
void set_timer()
{
    struct itimerval itv;
    itv.it_interval.tv_sec = 1;
    itv.it_interval.tv_usec = 0;
    itv.it_value.tv_sec = 1;
    itv.it_value.tv_usec = 0;
    setitimer(ITIMER_REAL, &itv, &oldtv);
}
 
void signal_handler(int m)
{
    count ++;
    printf("%d\n", count);
}
 
int main()
{
    signal(SIGALRM, signal_handler);
    set_timer();
    while(count < 10000);
    exit(0);
    return 1;
}

数据表不到1个G,然后程序运行起来后cpu一直处于98%~~100%之间

展开
收起
蛮大人123 2016-02-05 22:38:46 2652 0
1 条回答
写回答
取消 提交回答
  • 我说我不帅他们就打我,还说我虚伪

    while(count < 10000); 这个一直在跑 cpu自然就高了 可以usleep(100);

    2019-07-17 18:38:08
    赞同 展开评论 打赏
问答排行榜
最热
最新
相关电子书
更多
让 MySQL 原生分布式触手可及
立即下载
好的 MySQL 兼容可以做到什么程度
立即下载
云数据库RDS MySQL从入门到高阶
立即下载