• 技术文章 >后端开发 >php教程

    linuxloadavg算法_PHP教程

    2016-07-13 17:26:14原创407
    linux loadavg 算法
    发表人:biti_rainy
    今天读linux source code关于cpu load 的计算方法,同时在google上搜索到处参考,晕乎了半天,终于弄明白cpu load 的计算方法了,并不是简单的移动算术平均。
    对于linux来说,采样计算load时间间隔为5秒,这都是在source code里面定义的固定数字,其采样结构通过动态内存文件系统 /proc/loadavg 可以动态的得到适时数据,其他工具的输出,比如 uptime / top/sar 等都是读该内存数据所产生的。我们在这里主要考究kernel的算法。
    对于5秒的间隔,是动态地采样cpu状态数据,也就是run queue size ,这包括正在cpu中running的进程数量以及在cpu等待队列里面的进程数量。对于linux来说,实际上会计算1分钟、5分钟、15分钟的移动平均。为此首先我们要介绍linux 里面定义的3个常量:
    #define EXP_1 1884 /* 1/exp(5sec/1min) */
    #define EXP_5 2014 /* 1/exp(5sec/5min) */
    #define EXP_15 2037 /* 1/exp(5sec/15min) */
    三个常量分别表示1/5/15分钟的常量,计算方法是:
    1884 = 2048/(power(e,(5/(60*1)))) /* e = 2.71828 */
    2014 = 2048/(power(e,(5/(60*5))))
    2037 = 2048/(power(e,(5/(60*15))))
    我们假定前一时刻按常量1884计算的load为 load1(t-1),当前采样run queue size 为 rq1,则当前load1(t) = ((load1(t-1) * 1884) + rq1 * (2048 - 1884))/2048
    同理可以5分钟和15分钟移动平均的算法分别为 load5(t) = ((load5(t-1) * 2014) + rq1 * (2048 - 2014))/2048和load_15(t) = ((load15(t-1) * 2037) + rq1 * (2048 - 2037))/2048

    由此可以看出,移动平均间隔越大,当前run queue size 对移动平均的影响趋向减小。
    至于为什么取这个数,涉及到微积分方面的知识了,这样做出的图象更平滑。

    www.bkjia.comtruehttp://www.bkjia.com/PHPjc/532000.htmlTechArticlelinux loadavg 算法 发表人:biti_rainy 今天读linux source code关于cpu load 的计算方法,同时在google上搜索到处参考,晕乎了半天,终于弄明白cpu loa...

    php入门到就业线上直播课:查看学习

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    Linux系统运维及项目正式上线:点击学习

    专题推荐:linuxloadavg 算法 linux loadavg 算法 发表 biti rainy 今天 source
    上一篇:PHP4实际应用经验篇2_PHP教程 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• PHP底层的运行机制与原理_PHP教程• 说一说PHP程序开发中的模板选择_PHP• 程序修改有关问题• js表单提交解决方法• php 适用方法积累
    1/1

    PHP中文网