Linux内核中获取系统负载源代码

本是古典 何须时尚 2022-04-03 04:28 280阅读 0赞

Linux内核中获取系统负载

  • 内核中获取系统负载源代码

内核中获取系统负载源代码

//源码路径/fs/proc/loadavg.c

  1. #define LOAD_INT(x) ((x) >> FSHIFT)
  2. #define LOAD_FRAC(x) LOAD_INT(((x) & (FIXED_1-1)) * 100)
  3. static int loadavg_proc_show(struct seq_file *m, void *v)
  4. {
  5. unsigned long avnrun[3];
  6. get_avenrun(avnrun, FIXED_1/200, 0);
  7. seq_printf(m, "%lu.%02lu %lu.%02lu %lu.%02lu %ld/%d %d\n",
  8. LOAD_INT(avnrun[0]), LOAD_FRAC(avnrun[0]),
  9. LOAD_INT(avnrun[1]), LOAD_FRAC(avnrun[1]),
  10. LOAD_INT(avnrun[2]), LOAD_FRAC(avnrun[2]),
  11. nr_running(), nr_threads,
  12. task_active_pid_ns(current)->last_pid);
  13. return 0;
  14. }

在系统中查看loadavg的结果如下:
Alt
含义如下:
前三个数字大家都知道,是1、5、15分钟内的平均进程数。第四个数字中的分子是正在运行的进程数,分母是进程总数;第五个表示最近运行的进程ID。

发表评论

表情:
评论列表 (有 0 条评论,280人围观)

还没有评论,来说两句吧...

相关阅读

    相关 linux内核capable源代码分析

    linux内核里对于进程的权限管理有一个很重要的函数capable,以前看了好多遍,今天下决心搞定他,也在此立下一个碑,以后有谁想搞明白他的话,我还可以提供一些帮助。 ca

    相关 linux内核read操作源代码分析

    read操作是任何操作系统里的基本操作,我们来看一下在linux内核里,read文件是怎样实现的。 read函数在用户空间是由read系统调用实现的,由编译器编译成软中断i

    相关 linux 内核 获取随机数

    linux内核的熵池 Linux内核采用熵来描述数据的随机性。熵(entropy)是描述系统混乱无序程度的物理量,一个系统的熵越大则说明该系统的有序性越差,即不确定性越大