当前位置: 首页 > article >正文

6个Linux CPU调优实战技巧,第三个帮你解决CPU飙升

一、什么时候需要CPU调优服务响应变慢top看到CPU us或sy持续超过70%机器load average高于CPU核心数*2你怀疑某个进程占用了太多CPU想限制它或给它提权虚拟化环境里%steal高说明宿主机超售严重读完这篇你会能判断CPU瓶颈的类型会用工具定位热点敢动手改内核参数。前置条件能登录Linux服务器有root权限。我用Ubuntu 22.04内核5.15和CentOS 7内核3.10都测过。二、先把指标看懂别瞎调2.1top的第一行 load averageload average: 2.50, 3.10, 4.20这三个数分别是1分钟、5分钟、15分钟的平均活跃进程数正在运行等待运行的进程。注意它不是CPU使用率。怎么判断load高不高拿CPU核心数比较。比如4核机器load 4 算正常超过8说明有大量进程在排队。坑load高但CPU idle也高说明进程卡在I/O或锁上比如磁盘慢、网络等待。这时候调CPU没用。2.2top的CPU状态行%Cpu(s): 12.5 us, 3.2 sy, 0.0 ni, 84.0 id, 0.2 wa, 0.0 hi, 0.1 si, 0.0 st字段含义正常范围us用户态应用代码视业务长期80%考虑优化代码sy内核态系统调用、驱动通常10%过高可能锁竞争或驱动问题ninice值调整过的进程用户态一般很小id空闲越高越好wa等待I/O超过5%说明磁盘是瓶颈别调CPUhi硬件中断通常1%过高可能网卡中断风暴si软件中断通常3%过高可能网络流量大或驱动问题st虚拟机偷走的时间云上常见5%说明宿主机超售严重2.3 我推荐的一键看全局命令# 每秒刷新显示CPU、内存、磁盘、网络 vmstat 1 5 # 重点看r运行队列b阻塞进程cs上下文切换in中断us,sy,id,wa预期输出示例procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu----- r b swpd free buff cache si so bi bo in cs us sy id wa st 2 0 0 204800 10240 512000 0 0 10 20 500 8000 15 3 82 0 0cs上下文切换如果超过几万说明线程频繁切换考虑减少线程数或绑核。三、定位CPU热点谁在吃CPU3.1 用top找到最猛的进程top -o %CPU # 按CPU排序记下PID然后看它的线程top -H -p PID3.2 用pidstat看每个线程的CPU占用pidstat -t -p PID 1 # 每秒输出-t显示线程如果某个线程一直很高记下TID线程ID。3.3 用perf看热点函数终极武器# 采样30秒看CPU在哪里花时间 perf top -p PID # 或者记录后分析 perf record -p PID -g -- sleep 30 perf report你会看到一个火焰图式的调用栈。我当初用这个发现程序在疯狂调用strlen()原来是日志打印太频繁。彩蛋如果没装perf试试strace -c -p PID看系统调用耗时。不过strace开销大生产慎用。四、调优手段从软到硬4.1 调整进程优先级nicenice值范围-20到19越低优先级越高。普通用户只能调高降优先级root能调低提权。# 启动时指定nice nice -n -10 ./my_app # 调整已运行的进程 renice -n -5 -p 1234我推荐I/O密集型的数据库进程可以给高优先级比如-10而备份脚本给低优先级19。4.2 绑核CPU亲和性避免进程在核心间频繁迁移提高缓存命中率。# 查看进程当前绑定情况 taskset -p PID # 绑定到CPU 0,2掩码0b01015 taskset -p 5 PID # 启动时绑定 taskset -c 0,2 ./my_app注意别把关键进程和网络中断绑在同一个核。我一般把网卡中断绑到最后一个核应用绑到前几个。4.3 调整内核调度参数高手向这些参数在/proc/sys/kernel/下临时修改用sysctl -w永久写/etc/sysctl.conf。# 查看CFS调度器的唤醒抢占粒度默认4ms cat /proc/sys/kernel/sched_wakeup_granularity_ns # 减少抢占粒度提高交互性但吞吐会降 sysctl -w kernel.sched_wakeup_granularity_ns2000000我一般不碰这些除非你有非常明确的场景比如实时音视频。乱调可能让系统行为变得诡异。4.4 限制进程CPU使用cgroup用systemd或cgroup v2限制某个服务占用不超过2个核。# 创建一个cgroupcgroup v1 cgcreate -g cpu:/limited cgset -r cpu.cfs_quota_us200000 limited # 2核200ms内给200ms cgset -r cpu.cfs_period_us100000 limited # 把进程放进去 cgclassify -g cpu:/limited PID用systemd更简单编辑service文件加CPUQuota200%。五、实战案例Nginx CPU飙升到100%场景还原某天top看到nginx的CPU使用率100% us但流量没涨。重启后一会儿又上去。排查过程pidstat -t -p $(pidof nginx) 1看到worker线程CPU高。perf top -p 那个线程PID发现热点在ngx_http_log_handler。检查nginx配置发现access_log里用了$request_time而且日志级别开了debug。注释掉debug把日志格式简化CPU降到5%。教训日志格式里计算变量比如$request_time会消耗CPU。生产环境别开debug。六、彩蛋几个你可能不知道的CPU调优命令lscpu看CPU型号、核心数、NUMA拓扑。numactl --hardware看NUMA节点内存分布。跨节点访问内存慢绑核时尽量用同节点的内存。irqbalance服务自动分配中断到不同CPU但有时手动绑定效果更好。cpupower frequency-set -g performance把CPU频率策略设为性能模式笔记本默认是powersave。我踩过的坑在虚拟化环境KVM里宿主机超售太多你调guest没卵用。找云服务商换独享型实例。七、验证调优效果调完别重启就走。用压测工具跑一下# 安装stress sudo apt install stress # 制造4个CPU满负荷 stress --cpu 4 --timeout 60 # 同时用mpstat观察 mpstat -P ALL 1如果负载能压满且%sys不异常就算及格。生产验证灰度切流量观察半小时对比调优前后的平均响应时间和CPU使用率。八、常见问题真有人问过我Qload average很高但top里CPU idle也高为什么A进程在等I/O磁盘、网络或者被锁阻塞。用iostat -x 1看%util或者pidstat -d看进程读写。Q改nice值会影响其他进程吗A会。你给A提权B就相对被降权。别在生产环境随便renice -20除非你确定A非常重要。Qperf报No permissionA内核参数kernel.perf_event_paranoid默认2普通用户不能用。临时调成1sysctl -w kernel.perf_event_paranoid1。或者用sudo perf。Q我的CPU支持超线程应该把两个逻辑核当同一个物理核看待吗A对于计算密集型任务建议两个逻辑核不要同时满负荷否则会争抢执行单元。绑核时先查物理核IDcat /sys/devices/system/cpu/cpu*/topology/thread_siblings_list。九、总结一下先定位后调优用top、mpstat、vmstat看清瓶颈是us、sy还是wa。用户态高优化代码减少循环、缓存结果或调nice。内核态高看系统调用strace、锁竞争perf lock、中断/proc/interrupts。最后手段加CPU、换云主机规格。CPU调优是个细活不要为了调优而调优。如果系统响应已经满足SLA就别动了。你有没有遇到过CPU调优翻车的经历来评论区聊聊我帮你分析。

相关文章:

6个Linux CPU调优实战技巧,第三个帮你解决CPU飙升

一、什么时候需要CPU调优?服务响应变慢,top看到CPU us或sy持续超过70%机器load average高于CPU核心数*2你怀疑某个进程占用了太多CPU,想限制它或给它提权虚拟化环境里%steal高,说明宿主机超售严重读完这篇你会:能判断C…...

Mem Reduct:如何用2MB工具释放Windows系统300%内存潜力?

Mem Reduct:如何用2MB工具释放Windows系统300%内存潜力? 【免费下载链接】memreduct Lightweight real-time memory management application to monitor and clean system memory on your computer. 项目地址: https://gitcode.com/gh_mirrors/me/memr…...

基于Docker与BPMN.js的Activiti流程图云端部署实战

1. 从零认识Activiti与BPMN.js 如果你正在寻找一种简单高效的方式,将企业业务流程搬上云端,那么DockerBPMN.jsActiviti的组合绝对值得尝试。Activiti作为一款轻量级工作流引擎,能帮你把复杂的审批流程、任务流转自动化;BPMN.js则是…...

第9天:客户分层(下):构建动态的标签体系

核心观点:动态的客户分层依赖于一个设计精良的标签体系。标签是客户画像的基石,是实现一切个性化服务的基础。关键维度::记录客户通过哪个渠道进入私域。:追踪客户在私域内的关键行为,如浏览、点击、参与讨…...

Windows HEIC缩略图终极指南:3分钟搞定iPhone照片预览

Windows HEIC缩略图终极指南:3分钟搞定iPhone照片预览 【免费下载链接】windows-heic-thumbnails Enable Windows Explorer to display thumbnails for HEIC/HEIF files 项目地址: https://gitcode.com/gh_mirrors/wi/windows-heic-thumbnails 还在为Windows…...

Windows触控板三指拖拽终极指南:像Mac一样流畅操作

Windows触控板三指拖拽终极指南:像Mac一样流畅操作 【免费下载链接】ThreeFingersDragOnWindows Enables macOS-style three-finger dragging functionality on Windows Precision touchpads. 项目地址: https://gitcode.com/gh_mirrors/th/ThreeFingersDragOnWin…...

频谱分析仪功率测试避坑指南:从信号源选择到校准全流程(附常见问题排查)

频谱分析仪功率测试避坑指南:从信号源选择到校准全流程(附常见问题排查) 射频工程师的实验室里,频谱分析仪堪称"黄金右眼",但功率测试的误差却可能让这只眼睛"近视"甚至"失明"。我曾亲眼…...

如何永久备份微信聊天记录?免费本地工具WeChatMsg完整使用指南

如何永久备份微信聊天记录?免费本地工具WeChatMsg完整使用指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/…...

2026年OpenClaw(Clawdbot)京东云零门槛安装、大模型Coding Plan配置及使用方法【最全】

2026年OpenClaw(Clawdbot)京东云零门槛安装、大模型Coding Plan配置及使用方法【最全】。本文面向零基础用户,完整说明在轻量服务器与本地Windows11、macOS、Linux系统中部署OpenClaw(Clawdbot)的流程,包含…...

Ubuntu服务器优化:手动编译ixgbe驱动提升10G网卡性能(附RSS多队列配置)

Ubuntu服务器网络性能深度调优:手动编译ixgbe驱动与RSS多队列实战指南 当你的Ubuntu服务器需要处理每秒数十万级网络请求时,默认的ixgbe驱动可能成为性能瓶颈。上周我们的视频转码集群就遇到了这样的问题——在10G网络环境下,系统日志频繁出现…...

WeChatMsg数据提取架构深度解析:微信聊天记录永久化存储的实现机制

WeChatMsg数据提取架构深度解析:微信聊天记录永久化存储的实现机制 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trend…...

颠覆传统认知!Science新研究|学习让大脑神经元更“合群”,而非更“独立”

当你在某项技能上愈发熟练,比如在人群中一眼认出熟悉的面孔、快速发现文字里的拼写错误,或是精准预测游戏中的下一步动作时,大脑中的感觉神经元并不会变得更独立地工作,反而会变得愈发协调,彼此共享信息、协同行动。这…...

如何用WeChatMsg永久保存你的数字记忆?3步掌握数据主权

如何用WeChatMsg永久保存你的数字记忆?3步掌握数据主权 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/WeCh…...

伺服调试手记:用Wireshark抓包分析CanOpen SDO 0x80错误(附真实报文解读)

伺服调试手记:用Wireshark抓包分析CanOpen SDO 0x80错误 那天下午三点,车间里的伺服驱动器突然亮起了报警灯。显示屏上赫然显示着"SDO 0x80错误"——这个在CanOpen通信中常见的错误代码,背后可能藏着参数越界、子索引不存在等多种问…...

高效备战2026年上海汉字小达人【字义溯源】单选题:高频考点精编

最近,陆陆续续有家长朋友和孩子问我,2026年美丽汉字小达人活动具体安排是什么?考些什么?有哪些题型?如何高效准备2026年汉字小达人?有没有高频考点可以快速备考?...... 跟着TOP练与学来了解吧&a…...

保姆级教程:在QGroundControl地图上可视化无人机盘旋半径(从QML到C++数据流)

深度解析QGroundControl中无人机盘旋半径的动态可视化实现 在无人机地面站软件开发中,实时可视化飞行参数是一个关键但常被忽视的细节。以QGroundControl(QGC)为例,当操作者调整盘旋半径时,地图上的圆形标记需要即时响应变化——这看似简单的…...

GLM-OCR模型在操作系统镜像处理中的应用:自动化提取配置信息

GLM-OCR模型在操作系统镜像处理中的应用:自动化提取配置信息 你有没有遇到过这样的麻烦事?接手一批新的服务器或者虚拟机,需要整理它们的配置信息,比如IP地址、主机名、系统版本。你只能一台一台登录,手动把屏幕上的信…...

Python图像处理入门指南:从基础到实战

1. 为什么选择Python做图像处理? 第一次接触图像处理时,我也纠结过该用什么工具。试过Photoshop这类图形软件后,发现它们虽然功能强大,但没法自动化处理大批量图片。后来转向编程方案,在C和Python之间犹豫了很久&#…...

利用SNAP高效转换Sentinel-2 L2A数据:从hdr到tif的实战指南

1. 为什么需要转换Sentinel-2 L2A数据格式? 很多刚开始接触遥感数据处理的朋友都会有这样的疑问:为什么不能直接用下载的原始数据?我刚开始用Sentinel-2数据时也这么想过,直到在实际项目中碰了几次壁才明白格式转换的重要性。 Sen…...

VideoDownloadHelper视频下载助手:如何轻松保存网页视频的完整指南

VideoDownloadHelper视频下载助手:如何轻松保存网页视频的完整指南 【免费下载链接】VideoDownloadHelper Chrome Extension to Help Download Video for Some Video Sites. 项目地址: https://gitcode.com/gh_mirrors/vi/VideoDownloadHelper 你是否曾经遇到…...

保姆级教程:在Ubuntu 22.04上手动配置Ollama为Systemd服务(附用户权限管理详解)

深度解析:Ubuntu 22.04下Ollama的Systemd服务化与安全权限实践 在开源工具链中,Ollama作为轻量级模型服务框架正获得越来越多开发者的青睐。但生产环境中,简单的curl | sh安装方式往往隐藏着权限失控和服务不稳定的隐患。本文将彻底解构手动配…...

从HMM到CRF:命名实体识别模型演进简史与sklearn-crfsuite快速入门

从HMM到CRF:命名实体识别模型演进简史与sklearn-crfsuite快速入门 在自然语言处理的众多任务中,命名实体识别(NER)扮演着关键角色——它像一位精准的文本考古学家,能从杂乱无章的字符序列中挖掘出人名、地名、机构名等…...

招投标采购管理系统_采购管理软件_采购系统_招标采购系统源码+数据库BS架构

1. 供应商管理信息全量记录:系统全面留存供应商基础信息,涵盖公司全称、联系方式、主营产品/服务、资质文件等核心内容,实现信息集中管控,避免遗漏。多维综合评估:从资质合规性、过往合作表现、市场信誉度、履约能力等…...

AsrTools终极指南:5分钟快速上手免费语音转文字工具

AsrTools终极指南:5分钟快速上手免费语音转文字工具 【免费下载链接】AsrTools ✨ AsrTools: Smart Voice-to-Text Tool | Efficient Batch Processing | User-Friendly Interface | No GPU Required | Supports SRT/TXT Output | Turn your audio into accurate te…...

Xournal++ 手写笔记软件:解决数字笔记三大痛点的完整方案

Xournal 手写笔记软件:解决数字笔记三大痛点的完整方案 【免费下载链接】xournalpp Xournal is a handwriting notetaking software with PDF annotation support. Written in C with GTK3, supporting Linux (e.g. Ubuntu, Debian, Arch, SUSE), macOS and Windows…...

NVIDIA Profile Inspector终极指南:解锁显卡隐藏性能的3个简单步骤

NVIDIA Profile Inspector终极指南:解锁显卡隐藏性能的3个简单步骤 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector 你是否觉得NVIDIA官方控制面板的设置选项太过有限?是否想要为…...

手把手教你用Orbbec Astra Pro在ROS中实现ORB-SLAM2(Ubuntu16.04环境)

深度视觉实战:Orbbec Astra Pro与ORB-SLAM2在ROS中的全流程部署指南 当三维视觉遇上机器人操作系统,会碰撞出怎样的火花?如果你正在寻找一套高性价比的RGB-D SLAM解决方案,Orbbec Astra Pro与ORB-SLAM2的组合绝对值得尝试。本文将…...

FitGirl游戏启动器:5分钟掌握专业游戏管理解决方案

FitGirl游戏启动器:5分钟掌握专业游戏管理解决方案 【免费下载链接】Fitgirl-Repack-Launcher An Electron launcher designed specifically for FitGirl Repacks, utilizing pure vanilla JavaScript, HTML, and CSS for optimal performance and customization …...

LinkSwift:基于JavaScript的网盘直链解析技术架构分析

LinkSwift:基于JavaScript的网盘直链解析技术架构分析 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国移动云盘 / 天翼…...

AI写代码:告别重复造轮子的高效开发术

告别重复造轮子:Codex写脚本的技术文章大纲核心主题探讨如何利用OpenAI Codex等AI工具高效生成脚本代码,避免重复开发常见功能模块,提升开发效率与代码质量。技术背景Codex的工作原理:基于GPT-3的代码生成模型,支持多种…...