zoukankan      html  css  js  c++  java
  • 获取CPU使用情况信息(转)

    获取了内存使用情况,也可以使用PHP的 getrusage()获取CPU使用情况,该方法在windows下不可用。 
     
    Php代码 
    1. print_r(getrusage());  
    2. /* 输出 
    3. Array 
    4. ( 
    5. [ru_oublock] => 0 
    6. [ru_inblock] => 0 
    7. [ru_msgsnd] => 2 
    8. [ru_msgrcv] => 3 
    9. [ru_maxrss] => 12692 
    10. [ru_ixrss] => 764 
    11. [ru_idrss] => 3864 
    12. [ru_minflt] => 94 
    13. [ru_majflt] => 0 
    14. [ru_nsignals] => 1 
    15. [ru_nvcsw] => 67 
    16. [ru_nivcsw] => 4 
    17. [ru_nswap] => 0 
    18. [ru_utime.tv_usec] => 0 
    19. [ru_utime.tv_sec] => 0 
    20. [ru_stime.tv_usec] => 6269 
    21. [ru_stime.tv_sec] => 0 
    22. ) 
    23. */  
     
     
    这个结构看上出很晦涩,除非你对CPU很了解。下面一些解释: 
    • ru_oublock: 块输出操作
    • ru_inblock: 块输入操作
    • ru_msgsnd: 发送的message
    • ru_msgrcv: 收到的message
    • ru_maxrss: 最大驻留集大小
    • ru_ixrss: 全部共享内存大小
    • ru_idrss:全部非共享内存大小
    • ru_minflt: 页回收
    • ru_majflt: 页失效
    • ru_nsignals: 收到的信号
    • ru_nvcsw: 主动上下文切换
    • ru_nivcsw: 被动上下文切换
    • ru_nswap: 交换区
    • ru_utime.tv_usec: 用户态时间 (microseconds)
    • ru_utime.tv_sec: 用户态时间(seconds)
    • ru_stime.tv_usec: 系统内核时间 (microseconds)
    • ru_stime.tv_sec: 系统内核时间?(seconds)
     
    要看到你的脚本消耗了多少CPU,我们需要看看“用户态的时间”和“系统内核时间”的值。秒和微秒部分是分别提供的,您可以把微秒值除以100万,并把它添加到秒的值后,可以得到有小数部分的秒数。 
     
    Php代码 
    1. // sleep for 3 seconds (non-busy)  
    2. sleep(3);  
    3. $data = getrusage();  
    4. echo “User time: “.  
    5. ($data['ru_utime.tv_sec'] +  
    6. $data['ru_utime.tv_usec'] / 1000000);  
    7. echo “System time: “.  
    8. ($data['ru_stime.tv_sec'] +  
    9. $data['ru_stime.tv_usec'] / 1000000);  
    10. /* 输出 
    11. User time: 0.011552 
    12. System time: 0 
    13. */  
     
    sleep是不占用系统时间的,我们可以来看下面的一个例子: 
     
    Php代码 
    1. // loop 10 million times (busy)  
    2. for($i=0;$i<10000000;$i++) {  
    3. }  
    4. $data = getrusage();  
    5. echo “User time: “.  
    6. ($data['ru_utime.tv_sec'] +  
    7. $data['ru_utime.tv_usec'] / 1000000);  
    8. echo “System time: “.  
    9. ($data['ru_stime.tv_sec'] +  
    10. $data['ru_stime.tv_usec'] / 1000000);  
    11. /* 输出 
    12. User time: 1.424592 
    13. System time: 0.004204 
    14. */  
     
     
     
    这花了大约14秒的CPU时间,几乎所有的都是用户的时间,因为没有系统调用。 
    系统时间是CPU花费在系统调用上的上执行内核指令的时间。下面是一个例子: 
     
    Php代码 
    1. $start = microtime(true);  
    2. // keep calling microtime for about 3 seconds  
    3. while(microtime(true) – $start < 3) {  
    4. }  
    5. $data = getrusage();  
    6. echo “User time: “.  
    7. ($data['ru_utime.tv_sec'] +  
    8. $data['ru_utime.tv_usec'] / 1000000);  
    9. echo “System time: “.  
    10. ($data['ru_stime.tv_sec'] +  
    11. $data['ru_stime.tv_usec'] / 1000000);  
    12. /* prints 
    13. User time: 1.088171 
    14. System time: 1.675315 
    15. */  
     
     
    我们可以看到上面这个例子更耗CPU。 
  • 相关阅读:
    sortColors
    搜索二维矩阵
    矩阵置零
    求解最大子数组的和
    length of the longest substring without repeating character
    求解最大回文子字符串
    求两数的和
    验证回文串的一点解题思路
    fiddler-10-结合 Mock.js 伪接口数据进行测试(下)
    fiddler-9-结合 Mock.js 伪接口数据进行测试(上)
  • 原文地址:https://www.cnblogs.com/xingmeng/p/3198602.html
Copyright © 2011-2022 走看看