gettimeofday函数_内核态调测工具:ftrace(六)-ftrace应用:跟踪&统计函数耗时

问题

实际应用中,当系统CPU压力较大,某些固定频率触发的任务突然不稳定起来,或者出现(比较关注性能的)某函数的执行耗时出现波动,这种情况是为什么呢?是函数本身不稳定,还是系统导致?

举例test.c:

#include <stdio.h>
#include <sys/time.h>

int delaytime(int t) {
        int i, j;
        for (i = 0; i < t; i++)
                for (j = 0; j < 5000; j++);
}

void main() {
        struct timeval tv1, tv2;

        gettimeofday(&tv1, NULL);
        delaytime(100);
        gettimeofday(&tv2, NULL);

        printf("diff: %ldusn", 1000000 * (tv2.tv_sec - tv1.tv_sec) + (tv2.tv_usec - tv1.tv_usec));
}

如下执行:

$ stress -c 8 &
$ taskset -c 6 ./test
diff: 1045us
$ taskset -c 6 ./test
diff: 1124us
$ taskset -c 6 ./test
diff: 1444us
$ taskset -c 6 ./test
diff: 2162us
$ taskset -c 6 ./test
diff: 11995us
$ taskset -c 6 ./test
diff: 1067us

如上,一个固定的for循环在CPU加压的情况下,执行耗时不再稳定。

Ftrace跟踪

利用之前讲到的知识

Hello小崔:内核态调测工具:ftrace(三)-ftrace在C程序中应用​zhuanlan.zhihu.com
zhihu-card-default.svg

在test.c中添加跟踪代码:

$ cat test_trace.c
#include <stdio.h>
#include <sys/time.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>

int delaytime(int t) {
        int i, j;
        for (i = 0; i < t; i++)
                for (j = 0; j < 5000; j++);
}

void main() {
        struct timeval tv1, tv2;
        int fd_sched = open("/sys/kernel/debug/tracing/events/sched/enable", O_CREAT | O_RDWR, 0666);
        int fd_irq = open("/sys/kernel/debug/tracing/events/irq/enable", O_CREAT | O_RDWR, 0666);
        int fd_mark = open("/sys/kernel/debug/tracing/trace_marker", O_CREAT | O_RDWR, 0666);
        int fd_trace = open("/sys/kernel/debug/tracing/tracing_on", O_CREAT | O_RDWR, 0666);

        write(fd_trace, "1", 2); // enable ftrace
        write(fd_sched, "1", 2); // enable sched event
        write(fd_irq, "1", 2); // enable irq event

        while (1) {
          
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值