微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Linux:使用性能调控器时,为什么CPU频率会发生波动?

我正在使用Debian 8 amd64机器进行基准测试.在实验过程中,我希望cpu以固定频率(最好是可能的最大频率)运行.这将排除cpu时钟速度作为结果变化的来源.

经过一些阅读后,似乎正确的做法是将cpu调控器更改为性能,如here in the Linux kernel documentation所述:

The cpufreq governor “performance” sets the cpu statically to the
highest frequency within the borders of scaling_min_freq and
scaling_max_freq.

遗憾的是,未提供有关scaling_min_freq和scaling_max_freq的更多详细信息.希望它无关紧要,因为使用的cpu频率是间隔的最大值.

所以我使用cpufreq-set启用了这个调控器:

$cat /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor
performance
performance
performance
performance

为了更好的衡量,我还在BIOS中禁用了turbo boost模式:

$cat /sys/devices/system/cpu/intel_pstate/no_turbo
1

基于以上对性能调控器的描述,我预计cpu时钟速度不会有波动.然而,如果我反复运行cpufreq-info,我会看到时钟速度波动:

$cpufreq-info | grep 'current cpu fr'
  current cpu frequency is 4.00 GHz.
  current cpu frequency is 3.99 GHz.
  current cpu frequency is 4.00 GHz.
  current cpu frequency is 4.00 GHz.
$cpufreq-info | grep 'current cpu fr'
  current cpu frequency is 4.00 GHz.
  current cpu frequency is 4.00 GHz.
  current cpu frequency is 4.00 GHz.
  current cpu frequency is 3.96 GHz.
$cpufreq-info | grep 'current cpu fr'
  current cpu frequency is 4.00 GHz.
  current cpu frequency is 4.00 GHz.
  current cpu frequency is 4.00 GHz.
  current cpu frequency is 3.94 GHz.
$cpufreq-info | grep 'current cpu fr'
  current cpu frequency is 4.01 GHz.
  current cpu frequency is 4.00 GHz.
  current cpu frequency is 4.00 GHz.
  current cpu frequency is 3.98 GHz.

这种波动是由于硬件,BIOS,内核还是其他因素造成的?有没有办法设置cpu频率,使其根本不会波动?

解决方法

经过一些实验,我想我可以回答我自己的问题.

in this thread所述,在某些英特尔硬件上,有两种方法可以管理cpu频率:

>使用pstate.
>使用常规ACPI.

当使用pstate时,BIOS在时钟速度上有一些说法,似乎这是波动的来源.

您可以通过将intel_pstate = disable附加到内核参数来强制关闭pstate(编辑/ etc / default / grub并将arg添加到GRUB_CMDLINE_LINUX_DEFAULT.最后运行sudo update-grub).

执行此操作后,cpufreq-info的输出看起来大不相同,我还注意到一组不同的cpu管理器可用(例如,现在可以使用ondemand).

最重要的是,在将调速器设置为性能之后,时钟速度现在已经固定(在我的情况下为4.00GHz).

您可以查看/ sys / devices / system / cpu / cpu * / cpufreq / scaling_driver以确定是否正在使用pstate或ACPI来扩展cpu.这些文件可以采用值acpi-cpufreq或intel_pstate.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


在Linux上编写运行C语言程序,经常会遇到程序崩溃、卡死等异常的情况。程序崩溃时最常见的就是程序运行终止,报告 Segmentation fault (core dumped) 错误。而程序卡死一般来源于代码逻辑的缺陷,导致了死循环、死锁等问题。总的来看,常见的程序异常问题一般可以分为 非法内存访
git使用小结很多人可能和我一样,起初对git是一无所知的。我也是因为一次偶然的机会接触到git,并被它强大的功能所蛰伏。git其实就是一种版本控制工具,就像svn一样,但是git是分布式的。我不想给git打广告,我们直入正题——git能帮我们做什么?1)源码版本控制。平常写一写demo程序可能和g
1. 操作系统环境、安装包准备 宿主机:Max OSX 10.10.5 虚拟机:Parallel Desktop 10.1.1 虚拟机操作系统:CentOS 7 x86_64 DVD 1511.iso Oracle:linux.x64_11gR2_database_1of2.zip linux.x6
因为业务系统需求,需要对web服务作nginx代理,在不断的尝试过程中,简单总结了一下常见的nginx代理配置。 1. 最简反向代理配置 在http节点下,使用upstream配置服务地址,使用server的location配置代理映射。 upstream my_server { server 10
Linux模块机制浅析 Linux允许用户通过插入模块,实现干预内核的目的。一直以来,对linux的模块机制都不够清晰,因此本文对内核模块的加载机制进行简单地分析。 模块的Hello World! 我们通过创建一个简单的模块进行测试。首先是源文件main.c和Makefile。 f...
一、Hadoop HA的Web页面访问 Hadoop开启HA后,会同时存在两个Master组件提供服务,其中正在使用的组件称为Active,另一个作为备份称为Standby,例如HDFS的NameNode、YARN 的ResourceManager。HDFS的web页面只有通过Active的Name
一个简单的通用Makefile实现Makefile是Linux下程序开发的自动化编译工具,一个好的Makefile应该准确的识别编译目标与源文件的依赖关系,并且有着高效的编译效率,即每次重新make时只需要处理那些修改过的文件即可。Makefile拥有很多复杂的功能,这里不可能也没必要一一介绍,为了
Linux内核源码分析方法一、内核源码之我见Linux内核代码的庞大令不少人“望而生畏”,也正因为如此,使得人们对Linux的了解仅处于泛泛的层次。如果想透析Linux,深入操作系统的本质,阅读内核源码是最有效的途径。我们都知道,想成为优秀的程序员,需要大量的实践和代码的编写。编程固然重要,但是往往
题记:自从接触到“跳板机”的概念后,一直就被烦不胜烦的机器名,ip地址,用户名,密码折腾的死去活来,心说能有个小精灵随时帮我输入那些重复的登录信息就好了。我见过最挫的方式就是用记事本把一堆机器的ip、登录用户、密码记录下来,每次登录机器就像是一场战斗:打开笔记本 勾选复制 写ssh命令 登录 再打开
统计一下你写过多少代码最近整理了一下自己从开始学习编程以来写过的程序和代码,林林总总,花了不少的时间,最后把一些自认为还算不错的代码提交到github上做一个简单的分类和备份。当然我并不奢求它们能成为多好的开源代码,只是希望通过这种方式分享自己的劳动成果罢了。如果大家有兴趣可以访问我的github,