`
zizihaier
  • 浏览: 56509 次
  • 性别: Icon_minigender_2
  • 来自: 成都
社区版块
存档分类
最新评论

cpu性能

    博客分类:
  • Unix
阅读更多
首先介绍一下Linux kernel中的调度器(scheduler),调度器负责调度系统中的两种资源,一是线程,二是中断。调度器给不同资源不同的优先级。从高到低为:
1. 硬件中断(Hardware Interrupts)--这些请求由硬件触发,比如磁盘已经完成了读写任务或是网卡受到了新的数据包。
2. 软件中断(Software Interrupts)--这里指的是维护内核运行的内核态软件中断。比如内核的时钟管理进程。
3. 实时进程(Real time threads)--实时进程比内核本身具备更高的优先级,它可以抢占内核的CPU时间片,在2.4内核是一个不可抢占的内核,里面不支持实时程序。
4. 内核进程(Kernel threads)--包括所以的内核程序。
5. 用户进程(User threads)-- 所有运行在用户态的进程。
关于CPU,有3个重要的概念:上下文切换(context switchs),运行队列(Run queue)和使用率(utilization)
上下文切换:目前流行的CPU在同一时间内只能运行一个线程,超线程的处理器可以在同一时间运行多个线程(包括多核CPU),Linux内核会把多核的处理器当作多个单独的CPU来识别。一个标准的Linux内核何以支持运行50~50000个进程运行,对于普通的CPU,内核会调度和执行这些进程。每个进程都会分到CPU的时间片来运行,当一个进程用完时间片或者被更高优先级的进程抢占后,它会备份到CPU的运行队列中,同时其他进程在CPU上运行。这个进程切换的过程被称作上下文切换。过多的上下文切换会造成系统很大的开销。
运行队列:每个CPU都会维持一个运行队列,理想情况下,调度器会不断让队列中的进程运行。进程不是处在sleep状态就是run able状态。 如果CPU过载,就会出现调度器跟不上系统的要求,导致可运行的进程会填满队列。队列愈大,程序执行时间就愈长。“load”用来表示运行队列,用top命令我们可以看到CPU在1分钟,5分钟和15分钟内的运行队列的大小。这个值越大表明系统负荷越大。
CPU使用率:CPU使用率可分为一下几个部分:
User Time—执行用户进程的时间百分比;
System Time—执行内核进程和中断的时间百分比;
Wait IO—因为IO等待而使CPU处于idle状态的时间百分比;
Idle—CPU处于Idle状态的时间百分比。
关于时间片和动态优先级:
时间片对于CPU来说是很关键的参数,如果时间片太长,就会使系统的交互性能变差,用户感觉不到并行。如果太短,又会造成系统频繁的上下文切换,使性能下降。对于IO Bound的系统来讲并不需要太长的时间片,因为系统主要是IO操作;而对于CPU Bound的系统来说需要长的时间片以保持cache的有效性。
每一个进程启动的时候系统都会给出一个默认的优先级,但在运行过程中,系统会根据进程的运行状况不断调整优先级,内核会升高或降低进程的优先级(每次增加或降低5),判断标准是根据进程处于sleep状态的时间。IO Bound进程大部分时间在sleep状态,所以内核会调高它的优先级,CPU Bound进程会被内核惩罚降低优先级。因此,如果一个系统上既运行IO Bound进程,又运行CPU Bound进程,我们会发现,IO Bound进程的性能不会下降,而CPU Bound进程性能会不断下降。
我们运行一个CPU Bound的程序:cpu-hog。用ps命令可以看出它的优先级在不断下降。
term1# ./cpu-hog
term2# while :; do ps -eo pid,ni,pri,pcpu,comm | egrep 'hog|PRI'; sleep 1; done

PID NI PRI %CPU COMMAND
22855 0 20 84.5 cpu-hog
PID NI PRI %CPU COMMAND
22855 0 18 89.6 cpu-hog
PID NI PRI %CPU COMMAND
22855 0 15 92.2 cpu-hog
PID NI PRI %CPU COMMAND
22855 0 15 93.8 cpu-hog
我们运行find命令,是一个IO Bound的程序,可以观察到它的优先级不断提高。
term1# find /
term2# while :; do ps -eo pid,ni,pri,pcpu,comm | egrep 'find|PRI';sleep 1; done

PID NI PRI %CPU COMMAND
23101 0 20 0.0 find
PID NI PRI %CPU COMMAND
23101 0 21 4.0 find
PID NI PRI %CPU COMMAND
23101 0 23 3.5 find
PID NI PRI %CPU COMMAND
23101 0 23 4.3 find
PID NI PRI %CPU COMMAND
23101 0 23 4.2 find
PID NI PRI %CPU COMMAND
23101 0 23 4.4 find
如果同时运行2个程序就可看出明显的变化
# while :; do ps -eo pid,ni,pri,pcpu,comm | egrep 'find|hog';sleep 1; done
PID NI PRI %CPU COMMAND
23675 0 20 70.9 cpu-hog
23676 0 20 5.6 find
23675 0 20 69.9 cpu-hog
23676 0 21 5.6 find
23675 0 20 70.6 cpu-hog
23676 0 23 5.8 find
23675 0 19 71.2 cpu-hog
23676 0 23 6.0 find
23675 0 19 71.8 cpu-hog
23676 0 23 6.1 find
23675 0 18 72.8 cpu-hog
23676 0 23 6.2 find
23675 0 16 73.2 cpu-hog
23676 0 23 6.6 find
23675 0 14 73.9 cpu-hog
正如我们之前讨论的任何系统的性能比较都是基于基线的,并且监控CPU的性能就是以上3点,运行队列、CPU使用率和上下文切换。以下是一些对于CPU很普遍的性能要求:
1. 对于每一个CPU来说运行队列不要超过3,如果是双核CPU就不要超过6;
2. 如果CPU在满负荷运行,应该符合下列分布,
a) User Time:65%~70%
b) System Time:30%~35%
c) Idle:0%~5%
3. 对于上下文切换要结合CPU使用率来看,如果CPU使用满足上述分布,大量的上下文切换也是可以接受的。
常用的监视工具有,vmstat, top,dstat和mpstat.
# vmstat 1
procs -----------memory---------- ---swap-- -----io---- --system-- ----cpu----
r b swpd free buff cache si so bi bo in cs us sy id wa
0 0 104300 16800 95328 72200 0 0 5 26 7 14 4 1 95 0
0 0 104300 16800 95328 72200 0 0 0 24 1021 64 1 1 98 0
0 0 104300 16800 95328 72200 0 0 0 0 1009 59 1 1 98 0
r表示运行队列的大小,
b表示由于IO等待而block的线程数量,
in表示中断的数量,
cs表示上下文切换的数量,
us表示用户CPU时间,
sys表示系统CPU时间,
wa表示由于IO等待而是CPU处于idle状态的时间,
id表示CPU处于idle状态的总时间。
dstat可以给出每一个设备产生的中断数:
# dstat -cip 1
----total-cpu-usage---- ----interrupts--- ---procs---
usr sys idl wai hiq siq| 15 169 185 |run blk new
6    1    91    2    0   0| 12    0 13 | 0 0 0
1    0    99    0    0   0| 0     0 6   | 0 0 0
0    0    100   0    0   0| 18    0 2   | 0 0 0
0    0    100   0    0   0| 0     0 3   | 0 0 0
我们可以看到这里有3个设备号15,169和185.设备名和设备号的关系我们可以参考文件/proc/interrupts, 这里185代表网卡eth1.
# cat /proc/interrupts
CPU0
0: 1277238713 IO-APIC-edge timer
6: 5 IO-APIC-edge floppy
7: 0 IO-APIC-edge parport0
8: 1 IO-APIC-edge rtc
9: 1 IO-APIC-level acpi
14: 6011913 IO-APIC-edge ide0
15: 15761438 IO-APIC-edge ide1
169: 26 IO-APIC-level Intel 82801BA-ICH2
185: 16785489 IO-APIC-level eth1
193: 0 IO-APIC-level uhci_hcd:usb1
mpstat可以显示每个CPU的运行状况,比如系统有4个CPU。我们可以看到:
# mpstat –P ALL 1
Linux 2.4.21-20.ELsmp (localhost.localdomain) 05/23/2006
05:17:31 PM CPU %user %nice %system %idle intr/s
05:17:32 PM all 0.00 0.00 3.19 96.53 13.27
05:17:32 PM 0 0.00 0.00 0.00 100.00 0.00
05:17:32 PM 1 1.12 0.00 12.73 86.15 13.27
05:17:32 PM 2 0.00 0.00 0.00 100.00 0.00
05:17:32 PM 3 0.00 0.00 0.00 100.00 0.00

总结的说,CPU性能监控包含以下方面:
检查系统的运行队列,确保每一个CPU的运行队列不大于3。
确保CPU使用分布满足70/30原则(用户70%,系统30%)。
如果系统时间过长,可能是因为频繁的调度和改变优先级。
CPU Bound进程总是会被惩罚(降低优先级)而IO Bound进程总会被奖励(提高优先级)。
分享到:
评论

相关推荐

    基于SPEC CPU2017的CPU性能对比分析.pdf

    基于SPEC CPU2017的CPU性能对比分析 本文主要介绍了基于SPEC CPU2017的CPU性能对比分析,旨在比较国产CPU Hi1616和Intel E5-2650v4的性能差异。SPEC CPU2017是一个国际权威的CPU性能测试工具,能够对CPU的计算速度...

    NAS CPU性能排名

    ### NAS CPU性能排名解析 随着网络存储技术的发展与普及,NAS(Network Attached Storage,网络附属存储)设备成为企业和家庭用户数据管理的重要工具。选择适合的CPU是构建高效稳定NAS系统的关键因素之一。本文将基于...

    让你的CPU性能提升35%的好软件

    标题中的“让你的CPU性能提升35%的好软件”指的是一个声称能显著提高计算机中央处理器(CPU)性能的程序。这种软件通常通过优化系统设置、清理资源占用、管理后台进程或提供超频功能来实现性能提升。在描述中,“很...

    Qzone前端CPU性能优化

    《Qzone前端CPU性能优化:构建流畅用户体验的艺术》 标题与描述:“Qzone前端CPU性能优化”,这不仅是一句简单的口号,而是Qzone技术团队在不断追求极致用户体验过程中的核心课题。在信息爆炸的时代,用户对网页...

    CPU性能指标排名(截至2020年1月)

    CPU性能指标排名是指根据一系列的基准测试结果,将不同型号的x86架构处理器按照其性能表现进行排序。截至2020年1月的CPU性能指标排名涵盖了超过3000个x86兼容CPU型号,这些CPU型号覆盖了从高端到低端的广泛市场。...

    笔记本CPU性能排行

    根据给定的“笔记本CPU性能排行”文件,我们可以深入探讨一系列关键知识点,这些知识点涵盖了不同制造商、系列、型号以及各种技术规格,对于理解笔记本CPU的性能及其演变具有重要意义。 ### 1. CPU架构与系列 - **...

    cpu性能查看器

    直接查看cpu性能,获取cpu各项性能指标信息。直接下载安装,双击后即可查看。

    CPU性能测试工具支持所有厂商所有型号CPU

    CPU性能测试工具支持所有厂商所有型号CPU

    CPU性能阶梯图

    CPU性能阶梯图,时间跨度1993-2014,图片不是特别清晰,放大能看清,内容很详细

    CPU性能查看

    在IT领域,CPU性能查看是系统管理和优化的重要环节。CPU(中央处理器)是计算机的核心组件,负责执行软件指令和处理数据。对CPU性能的监控可以帮助我们了解系统的运行状况,找出性能瓶颈,以及优化资源分配。以下是...

    如何24小时记录电脑的CPU性能等

    记录电脑 CPU 性能的 24 小时监控 在这篇文章中,我们将学习如何使用 Windows 自带的性能监控工具来记录电脑的 CPU 性能,并了解如何查看和分析记录下的数据,以便更好地了解电脑的性能状况。 记录电脑 CPU 性能的...

    Cpu 性能指标介绍

    CPU性能指标是衡量计算机处理器效能的关键参数,它们包括主频、外频、倍频和一些额外的技术,如超线程(HT)。以下是对这些概念的详细介绍: 1. **主频**:主频是指CPU内核工作的时钟频率,通常以兆赫(MHz)或吉赫...

    cpu加速\让你的CPU性能提升35%的好软件

    如果你的机子很老,不防一用,它可让你的CPU性能提升35%。

    2010CPU性能排行

    【CPU性能排行详解】 在2010年的CPU性能排行榜中,我们看到了一系列Intel和AMD的顶级处理器。这个排名展示了当时市场上最强大的处理器,对于消费者和专业人士来说,它提供了选择高性能计算平台的重要参考。 首先,...

    CPU性能测试.doc

    CPU性能测试文档安装指南 本文档提供了SPEC CPU2006套件的安装指南,涵盖了Unix、Linux和Mac OS X操作系统。该套件旨在评估CPU的性能,并提供了详细的安装步骤和注意事项。 安装步骤 1. 检查预备条件:在安装之前...

    双CPU性能是否两倍于单CPU的性能.pdf

    "双CPU性能是否两倍于单CPU的性能" 双CPU性能是否两倍于单CPU的性能,这是一个经常被讨论的话题。在这个问题中,我们可以看到,使用双CPU系统的性能是否等效双倍频率单CPU的性能。事实上,使用双CPU系统的性能不会...

    cpu性能测试linpack

    CPU性能测试是评估计算机处理器能力的关键环节,尤其是在Linux操作系统中,因为Linux提供了丰富的工具和方法来衡量硬件性能。本文将详细探讨如何使用Linpack在Linux环境下进行CPU性能测试。 Linpack是一款广泛应用...

    cpu-z,CPU性能检测

    《CPU-Z:全面解析CPU性能的专业工具》 CPU-Z是一款广受好评的CPU检测软件,专为用户提供了详尽的CPU性能数据,是电脑硬件爱好者和专业人士不可或缺的工具。这款软件小巧精悍,操作简单,无论是新手还是老鸟都能...

Global site tag (gtag.js) - Google Analytics