手动控制Linux CPU风扇:提高性能与降低噪音 (linux 手动控制cpu转速)

随着Linux操作系统的不断普及,越来越多的人开始使用它来完成各种任务。然而,随着处理器性能的不断提高,CPU温度的升高也成为了一个问题。为了解决这个问题,CPU风扇成为了必须的部件之一。然而,CPU风扇也会带来噪音问题。本文将介绍如何手动控制Linux CPU风扇来同时提高性能和降低噪音。

1. 为什么需要手动控制CPU风扇?

CPU风扇的主要作用是通过将空气引入机箱,将热量从CPU散热器中带走。这是保持CPU温度在安全范围内的关键。然而,当CPU温度超过可承受的范围时,风扇就会增加转速以散热。这会增加噪音,因为风扇越快就越嘈杂。

此外,很多CPU风扇使用PWM(脉冲宽度调制)来控制风扇的速度。这种方法可以根据CPU温度动态调整速度。但是,Linux系统可能无法正确地读取风扇的PWM信号,导致风扇始终以更高速度运转。这会降低CPU性能,并增加噪音。

因此,手动控制CPU风扇是一个很好的解决方案。这可以调整风扇的速度以适应不同的CPU负载和温度,从而提高系统性能并减少噪音。

2. 设置CPU风扇

在Linux上手动控制CPU风扇需要几个步骤。检查Linux系统是否支持手动风扇控制。这可以通过运行以下命令来实现:

$ cat /sys/devices/platform/coretemp.0/hwmon/hwmon1/pwm1_enable

如果输出为1,则代表系统支持手动控制CPU风扇。否则,需要对系统进行一些设置,以使其支持风扇控制。

第二步是确定您的CPU使用的是哪种风扇。这可以通过运行以下命令来实现:

$ cat /proc/cpuinfo | grep ‘model name’

该命令将返回CPU的详细信息,其中包括风扇型号。

接下来,使用以下命令将风扇调整为手动控制模式:

$ echo 1 | sudo tee /sys/devices/platform/coretemp.0/hwmon/hwmon1/pwm1_enable

接下来,确定您的风扇支持哪些PWM频率。这可以通过运行以下命令来实现:

$ cat /sys/class/hwmon/hwmon2/pwm1_max

该命令将返回风扇的更大PWM频率。通过此命令确定哪些频率可以使用。

您可以使用以下命令来控制风扇的转速:

$ echo 100 | sudo tee /sys/class/hwmon/hwmon2/pwm1

此命令将风扇的速度设置为100%,即更大速度。您可以根据您的需要调整频率以控制风扇的速度。

3. 结论

手动控制Linux CPU风扇可以显著提高系统性能并在不影响散热的情况下降低噪音。通过使用上述命令,您可以轻松地调整风扇的速度以适应不同的CPU负载和温度。这不仅使您能够更好地控制系统,还可以增强系统的稳定性和可靠性。

相关问题拓展阅读:

如何提高 linux cpu使用率

1.在系统维护的过程中,随时可能有需要查看CPU使用率,并根据相应信息分析系统状况的需要。在CentOS中,可以通过top命令来查看CPU使用状况。运行top命令后,CPU使用状态会以全屏的方式显示,并且会处在对话的模式–用基于top的命令,可以控制显示方式等等。退出top的命令为q(在top运行中敲q键一次)。top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器  可以直接使用top命令后,查看%MEM的内容。可以选择按进程查看或者按用户查看,如想查看oracle用户的进程内存使用情况的话可以使用如下的命令:  $top-uoracle2.释义:PID:进程的ID  USER:进程所有者  PR:进程的优先级别,越小越优先被执行  NInice:值  VIRT:进程占用的虚拟内存  RES:进程占用的物理内存  SHR:进程使用的共享内存  S:进程的状态。S表示休眠,R表示正在运行,Z表示僵死状态,N表示该进程优先值为负数  %CPU:进程占用CPU的使用率  %MEM:进程使用的物理内存和总内存的百分比  TIME+:该进程启动后占用的总的CPU时间,即占用CPU使用时间的累加值。  COMMAND:进程启动命令名称3.操作实例:  在命令行中输入“top”  即可启动top  top的全屏对话模式可分为3部分:系统信息栏、命令输入栏、进程列表栏。  之一部分–最上部的系统信息栏:  之一行(top):    “00:11:04”为系统当前时刻;    “3:35”为系统启动后到现在的运作时间;    “2users”为当前登录到系统的用户,更确切的说是登录到用户的终端数–同一个用户同一时间对系统多个终端的连接将被视为多个用户连接到系统,这里的用户数也将表现为终端的数目;    “loadaverage”为当前系统负载的平均值,后面的三个值分别为1分钟前、5分钟前、15分钟前进程的平均数,一般的可以认为这个数值超过CPU数目时,CPU将比较吃力的负载当前系统所包含的进程;  第二行(Tasks):    “59total”为当前系统进程总数;    “1running”为当前运行中的进程数;    “58sleeping”为当前处于等待状态中的进程数;    “0stoped”为被停止的系统进程数;    “0zombie”为被复原的进程数;  第三行(Cpus):    分别表示了CPU当前的使用率;  第四行(Mem):    分别表示了内存总量、当前使用量、空闲内存量、以及缓冲使用中的内存量;  第五行(Swap):    表示类别同第四行(Mem),但此处反映着交换分区(Swap)的使用情况。通常,交换分区(Swap)被频繁使用的情况,将被视作物理灶告悉内存不足而造成的。友竖  第二部分–中间部分的内部命令提示栏:  top运行中可以通过top的内部命令对进程的显示方式进行控制。内部命令如下表:  s  -改变画面更新频率  l-关闭或开启之一部分之一行top信息的表示  t-关闭或开启之一部分第二行Tasks和第三行Cpus信息的表示  m-关闭或开启之一部分第四行Mem和第五行Swap信息的表示  N-以PID的大小的顺序排列表示进程列表(第三部分后述)  P-以CPU占用率大小的顺序排列进程列表(第三部分后述)  M-以内存占用率大小的顺序排列进程列表(第三部分后述)  h-显示帮助  n-设置在进程列表所显示进程的数量  q-退出top  s-  改变画面更新周期  第三部分–最下部分的进程列表栏:  以PID区分的进程列表将根据所设定的画面更新时间定期的更新。通过top内部命令可以控制此处的显示方式pmap可以根据进程查看进程相关信息占用的内存情况,(进程号可以通过ps查隐乎看)如下所示:  $pmap-d5647ps  如下例所示:  $ps-e-o’pid,comm,args,pcpu,rsz,vsz,stime,user,uid’其中rsz是是实际内存  $ps-e-o’pid,comm,args,pcpu,rsz,vsz,stime,user,uid’|greporacle|sort-nrk  其中rsz为实际内存,上例实现按内存排序,由大到小在Linux下查看内存我们一般用free命令:#freetotalusedfreesharedbufferscachedMem:68236-/+buffers/cache:Swap:68116下面是对这些数值的解释:total:总计物理内存的大小。used:已使用多大。free:可用有多少。Shared:多个进程共享的内存总额。Buffers/cached:磁盘缓存的大小。第三行(-/+buffers/cached):used:已使用多大。free:可用有多少。第四行就不多解释了。区别:第二行(mem)的used/free与第三行(-/+buffers/cache)used/free的区别。这两个的区别在于使用的角度来看,之一行是从OS的角度来看,因为对于OS,buffers/cached都是属于被使用,所以他的可用内存是16176KB,已用内存是KB,其中包括,内核(OS)使用+Application(X,oracle,etc)使用的+buffers+cached.第三行所指的是从应用程序角度来看,对于应用程序来说,buffers/cached是等于可用的,因为buffer/cached是为了提高文件读取的性能,当应用程序需在用到内存的时候,buffer/cached会很快地被回收。所以从应用程序的角度来说,可用内存=系统freememory+buffers+cached。如上例:=16176+110652+接下来解释什么时候内存会被交换,以及按什么方交换。当可用内存少于额定值的时候,就会开会进行交换。如何看额定值:cat/proc/meminfo#cat/proc/meminfoMemTotal:kBMemFree:17456kBBuffers:111328kBCached:kBSwapCached:0kBActive:467236kBInactive:kBHighTotal:0kBHighFree:0kBLowTotal:kBLowFree:17456kBSwapTotal:kBSwapFree:kBDirty:8kBWriteback:0kBMapped:345360kBSlab:112344kBCommitted_AS:535292kBPageTables:2340kBVmallocTotal:kBVmallocUsed:272696kBVmallocChunk:kBHugePages_Total:0HugePages_Free:0Hugepagesize:2023kB用free-m查看的结果:#free-mtotalusedfreesharedbufferscachedMem:2605-/+buffers/cache:Swap:查看/proc/kcore文件的大小(内存镜像):#ll-h/proc/kcore-rrootroot4.1GJun1212:04/proc/kcore备注:占用内存的测量测量一个进程占用了多少内存,linux为我们提供了一个很方便的方法,/proc目录为我们提供了所有的信息,实际上top等工具也通过这里来获取相应的信息。/proc/meminfo机器的内存使用信息/proc/pid/mapspid为进程号,显示当前进程所占用的虚拟地址。/proc/pid/statm进程所占用的内存#cat/proc/self/statm输出解释CPU以及CPU0。。。的每行的每个参数意思(以之一行为例)为:参数解释/proc//statusSize(pages)任务虚拟地址空间的大小VmSize/4Resident(pages)应用程序正在使用的物理内存的大小VmRSS/4Shared(pages)共享页数0Trs(pages)程序所拥有的可执行虚拟内存的大小VmExe/4Lrs(pages)被映像到任务的虚拟内存空间的库的大小VmLib/4Drs(pages)程序数据段和用户态的栈的大小(VmData+VmStk)4dt(pages)04查看机器可用内存/proc/28248/>freetotalusedfreesharedbufferscachedMem:688-/+buffers/cache:Swap:70312我们通过free命令查看机器空闲内存时,会发现free的值很小。这主要是因为,在linux中有这么一种思想,内存不用白不用,因此它尽可能的cache和buffer一些数据,以方便下次使用。但实际上这些内存也是可以立刻拿来使用的。所以空闲内存=free+buffers+cached=total-usedtop命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。下面详细介绍它的使用方法。top-02:53:32up16days,6:34,17users,loadaverage:0.24,0.21,0.24Tasks:481total,3running,474sleeping,0stopped,4zombieCpu(s):10.3%us,1.8%sy,0.0%ni,86.6%id,0.5%wa,0.2%hi,0.6%si,0.0%stMem:ktotal,kused,41668kfree,383536kbuffersSwap:ktotal,7900kused,kfree,kcachedPIDUSERPRNIVIRTRESSHRS%CPU%MEMTIME+COMMAND32497jacky202369m222m31mR105.629:27.62firefox4788yiuwing202357m18m13mS50.55:42.44konsole5657Liuxiaof202385m159m30mS44.05:25.06firefox4455xiefc202342m124m30mR43.17:23.03firefox6188Liuxiaof202391m17m13mS40.50:01.16konsole统计信息区前五行是系统整体的统计信息。之一行是任务队列信息,同uptime命令的执行结果。其内容如下:01:06:48当前时间up1:22系统运行时间,格式为时:分1user当前登录用户数loadaverage:0.06,0.60,0.48系统负载,即任务队列的平均长度。三个数值分别为1分钟、5分钟、15分钟前到现在的平均值。第二、三行为进程和CPU的信息。当有多个CPU时,这些内容可能会超过两行。内容如下:Tasks:29total进程总数1running正在运行的进程数28sleeping睡眠的进程数0stopped停止的进程数0zombie僵尸进程数Cpu(s):0.3%us用户空间占用CPU百分比1.0%sy内核空间占用CPU百分比0.0%ni用户进程空间内改变过优先级的进程占用CPU百分比98.7%id空闲CPU百分比0.0%wa等待输入输出的CPU时间百分比0.0%hi0.0%si最后两行为内存信息。内容如下:Mem:191272ktotal物理内存总量173656kused使用的物理内存总量17616kfree空闲内存总量22023kbuffers用作内核缓存的内存量Swap:192772ktotal交换区总量0kused使用的交换区总量192772kfree空闲交换区总量123988kcached缓冲的交换区总量。内存中的内容被换出到交换区,而后又被换入到内存,但使用过的交换区尚未被覆盖,该数值即为这些内容已存在于内存中的交换区的大小。相应的内存再次被换出时可不必再对交换区写入。进程信息区统计信息区域的下方显示了各个进程的详细信息。首先来认识一下各列的含义。序号列名含义aPID进程idbPPID父进程idcRUSERRealusernamedUID进程所有者的用户ideUSER进程所有者的用户名fGROUP进程所有者的组名gTTY启动进程的终端名。不是从终端启动的进程则显示为?hPR优先级iNInice值。负值表示高优先级,正值表示低优先级jP最后使用的CPU,仅在多CPU环境下有意义k%CPU上次更新到现在的CPU时间占用百分比lTIME进程使用的CPU时间总计,单位秒mTIME+进程使用的CPU时间总计,单位1/100秒n%MEM进程使用的物理内存百分比oVIRT进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RESpSWAP进程使用的虚拟内存中,被换出的大小,单位kb。qRES进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATArCODE可执行代码占用的物理内存大小,单位kbsDATA可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kbtSHR共享内存大小,单位kbunFLT页面错误次数vnDRT最后一次写入到现在,被修改过的页面数。wS进程状态。D=不可中断的睡眠状态R=运行S=睡眠T=跟踪/停止Z=僵尸进程xCOMMAND命令名/命令行yWCHAN若该进程在睡眠,则显示睡眠中的系统函数名zFlags任务标志,参考sched.h默认情况下仅显示比较重要的PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND列。可以通过下面的快捷键来更改显示内容。更改显示内容通过f键可以选择显示的内容。按f键之后会显示列的列表,按a-z即可显示或隐藏对应的列,最后按回车键确定。按o键可以改变列的显示顺序。按小写的a-z可以将相应的列向右移动,而大写的A-Z可以将相应的列向左移动。最后按回车键确定。按大写的F或O键,然后按a-z可以将进程按照相应的列进行排序。而大写的R键可以将当前的排序倒转。==============================top命令使用过程中,还可以使用一些交互的命令来完成其它参数的功能。这些命令是通过快捷键启动的。<空格>:立刻刷新。P:根据CPU使用大小进行排序。T:根据时间、累计时间排序。q:退出top命令。m:切换显示内存信息。t:切换显示进程和CPU状态信息。c:切换显示命令名称和完整命令行。M:根据使用内存大小进行排序。W:将当前设置写入~/.toprc文件中。这是写top配置文件的推荐方法。可以看到,top命令是一个功能十分强大的监控系统的工具,对于系统管理员而言尤其重要。但是,它的缺点是会消耗很多系统资源。应用实例使用top命令可以监视指定用户,缺省情况是监视所有用户的进程。如果想查看指定用户的情况,在终端中按“U”键,然后输入用户名,系统就会切换为指定用户的进程运行界面。a.作用free命令用来显示内存的使用情况,使用权限是所有用户。b.格式freec.主要参数-b-k-m:分别以字节(KB、MB)为单位显示内存使用情况。-sdelay:显示每隔多少秒数来显示一次内存使用情况。-t:显示内存总和列。-o:不显示缓冲区调节列。d.应用实例free命令是用来查看内存使用情况的主要命令。和top命令相比,它的优点是使用简单,并且只占用很少的系统资源。通过-S参数可以使用free命令不间断地监视有多少内存在使用,这样可以把它当作一个方便实时监控器。#free-b-s5使用这个命令后终端会连续不断地报告内存使用情况(以字节为单位),每5秒更新一次。

如何在Linux上得到CPU的工作速度

对于多核的cpu

usleep 之后可能你的程序被迁移到另外一个cpu核心

你或许看看是否可以把你的程序绑定某个cpu核心

或者多瞎谨比较几次,如果前后2次不在一个核上,就重新计算

cat /proc/cpuinfo 得到的肯定是正磨祥基确的,延时直接用usleep 应该比你自己实现的好

如果内核使用了CPU Frequency scaling,有可能宴亮主频是会动态改变的。

linux 手动控制cpu转速的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux 手动控制cpu转速,手动控制Linux CPU风扇:提高性能与降低噪音,如何提高 linux cpu使用率,如何在Linux上得到CPU的工作速度的信息别忘了在本站进行查找喔。


数据运维技术 » 手动控制Linux CPU风扇:提高性能与降低噪音 (linux 手动控制cpu转速)