为了找到linux中的平均负载,我使用sys/sysinfo.h,其中包括linux/kernel.h,其中定义了以下结构:
struct sysinfo {
long uptime; /* Seconds since boot */
unsigned long loads[3]; /* 1, 5, and 15 minute load averages */
unsigned long totalram; /* Total usable main memory size */
unsigned long freeram; /* Available memory size */
unsigned long sharedram; /* Amount of shared memory */
unsigned long bufferram; /* Memory used by buffers */
unsigned long totalswap; /* Total swap space size */
unsigned long freeswap; /* swap space still available */
unsigned short procs; /* Number of current processes */
unsigned short pad; /* explicit padding for m68k */
unsigned long totalhigh; /* Total high memory size */
unsigned long freehigh; /* Available high memory size */
unsigned int mem_unit; /* Memory unit size in bytes */
char _f[20-2*sizeof(long)-sizeof(int)]; /* Padding: libc5 uses this.. */
};但我认为这不会带来真正的负担。
产出: 2552402,3214049236,134513148
这个价值是什么意思?
我们可以使用uptime命令找到当前负载:
$uptime
13:00:14 up 35 min, 2 users, load average: 1.07, 0.95, 0.80我找不到这两种输出之间的任何联系。
我在网上搜索过。这说,除以2^16 (65536)。我也试过了。(或按SI_LOAD_SHIFT进行移位1,即1 << SI_LOAD_SHIFT。因为65536 =1 << 16)
我使用有四个i3-2120处理器的计算机。“upitime”的输出与cpus的数量有关。平均值
发布于 2018-08-01 05:58:13
查看您提供的链接,您应该根据SI_LOAD_SHIFT常量(包括在sys/sysinfo.h中)缩放负载,并引入可用CPU的数量以将其转换为CPU使用率%:
struct sysinfo sysinf;
memset(&sysinf, 0, sizeof sysinf);
if (!sysinfo(&sysinf)) {
float f_load = 1.f / (1 << SI_LOAD_SHIFT);
printf("load average (1 min): %.2f (%.0f%% CPU)\n",
sysinf.loads[0] * f_load,
sysinf.loads[0] * f_load * 100/get_nprocs());
// process other loads as well of you need
}发布于 2012-09-06 15:52:05
负荷平均值用不动点算法表示。有关常量,请参见这里。我们看到最后的FSHIFT位用来表示分数部分。要获得负载平均值,您始终可以像/proc/loadavg一样这样做。
发布于 2012-09-13 10:25:13
我找到解决办法了。
我忘了调用sysinfo(&sysinfo_obj)函数。
https://stackoverflow.com/questions/12303141
复制相似问题