Linux系统性能调优技巧详解
Linux系统性能调优技巧详解
Linux 系统广泛应用于服务器、嵌入式设备以及开发工作站中,因此对其进行性能调优是保障系统高效运行的关键之一。性能调优不仅可以提高系统的响应速度,还能有效优化资源使用,避免瓶颈。在这篇文章中,我们将深入探讨 Linux 系统性能调优的几种常见方法,并展示相应的代码和工具使用。

1. 性能调优前的准备
在开始调优之前,我们需要明确调优的目标。通常,Linux 系统的性能瓶颈来自于 CPU、内存、磁盘 I/O 和网络这四大部分。调优前,首先要进行性能监控和瓶颈分析。以下工具可以帮助我们了解系统当前的状态:
- top:实时查看 CPU、内存使用情况,监控进程。
- htop:
top的增强版,带有更友好的界面。 - vmstat:显示内存、I/O、CPU的统计信息。
- iostat:监控磁盘I/O性能。
- sar:收集和报告系统活动信息。
- netstat:查看网络连接和状态。
- perf:用于 CPU 性能分析的强大工具。
1.1 使用 top 监控 CPU 和内存
top 是 Linux 中最常用的性能监控工具之一,输入以下命令可以查看系统当前的 CPU 和内存使用情况:
top
top 输出的关键部分包括:
load average:显示系统负载,数值越大表示系统负载越高,通常系统负载应控制在CPU核数的范围内。%CPU:每个进程的 CPU 占用率。%MEM:每个进程的内存占用率。
1.2 使用 iostat 监控磁盘I/O
磁盘 I/O 是服务器性能瓶颈的常见来源之一。iostat 工具可以帮助你了解系统的 I/O 使用情况:
iostat -x 1 5
该命令会每秒更新一次磁盘 I/O 状态,运行 5 次。输出的关键指标有:
- %util:磁盘的使用率。如果此值接近 100%,说明磁盘可能成为瓶颈。
- await:每次 I/O 操作的平均等待时间,值越小越好。

2. CPU性能调优
2.1 优化 CPU 亲和性
CPU 亲和性指的是将特定进程绑定到特定的 CPU 核心上,以减少进程切换和缓存抖动。可以通过 taskset 命令来设置进程的 CPU 亲和性。
例如,将某个进程(PID 为 1234)绑定到第 1 和第 2 号 CPU 核上:
taskset -c 0,1 -p 1234
这样可以减少进程在多个 CPU 核之间切换带来的性能损失。
2.2 优化 CPU 调度策略
Linux 提供了几种不同的 CPU 调度策略,适用于不同类型的任务。常见的调度策略有:
- SCHED_OTHER:默认的调度策略,适用于大多数进程。
- SCHED_FIFO:适用于实时任务的调度策略,优先级高于普通任务。
- SCHED_RR:实时任务的另一种策略,基于时间片轮转调度。
可以通过 chrt 命令来修改进程的调度策略。例如,将某个进程的调度策略设置为 SCHED_RR 并指定优先级 10:
chrt -r -p 10 1234

3. 内存调优
3.1 调整虚拟内存(swappiness)
虚拟内存(swap)是 Linux 在内存不足时将部分数据写入磁盘的一种机制。然而,频繁使用 swap 会导致性能下降。因此,可以通过调整 swappiness 参数来控制系统使用虚拟内存的频率。
查看当前系统的 swappiness 值:
cat /proc/sys/vm/swappiness
默认情况下,该值通常为 60,表示当系统使用到 40% 的物理内存时就会开始使用 swap。可以通过修改这个值来减少对 swap 的依赖。例如,将 swappiness 设置为 10:
sudo sysctl vm.swappiness=10
这意味着系统在使用到 90% 内存之前不会使用 swap。
3.2 内存清理
在长时间运行的服务器上,内存中的缓存和无用的进程可能会占用大量内存。可以通过以下命令来释放内存中的缓存和无用数据:
sudo sync; sudo echo 3 > /proc/sys/vm/drop_caches
此操作不会影响运行中的进程,但会释放文件系统缓存。
3.3 使用 HugePages 优化内存性能
HugePages 是 Linux 提供的一种内存管理机制,可以有效减少 TLB(翻译后备缓冲区)的命中率,从而提高内存访问效率。配置 HugePages 的步骤如下:
- 查看当前系统的 HugePages 配置:
cat /proc/meminfo | grep HugePages
- 修改系统的 HugePages 配置(以 1024 页为例):
sudo sysctl -w vm.nr_hugepages=1024
- 将配置写入
/etc/sysctl.conf文件,以便在系统重启后生效:
echo "vm.nr_hugepages=1024" | sudo tee -a /etc/sysctl.conf

4. 磁盘I/O调优
4.1 调整 I/O 调度算法
Linux 提供了多种 I/O 调度算法,适用于不同的磁盘操作模式:
- cfq:完全公平队列,适合桌面系统。
- deadline:基于时间的调度算法,适合数据库系统。
- noop:简单的 FIFO 队列,适合 SSD。
查看当前磁盘的调度算法:
cat /sys/block/sda/queue/scheduler
修改磁盘调度算法为 deadline:
echo deadline | sudo tee /sys/block/sda/queue/scheduler
4.2 调整读写缓存策略
Linux 系统中的磁盘缓存机制能够显著提高磁盘读写性能。可以通过 hdparm 工具来调整磁盘的缓存策略:
sudo hdparm -W1 /dev/sda
此命令开启磁盘的写缓存,能够提升写操作的性能。
4.3 RAID 配置优化
如果你的系统使用 RAID 配置,可以通过调整 RAID 阵列的 stripe_cache_size 来提高 RAID 的性能:
sudo echo 32768 > /sys/block/md0/md/stripe_cache_size
这个命令将 RAID 阵列的缓存大小设置为 32768,能够显著提升 RAID 的写性能。

5. 网络性能调优
5.1 调整 TCP 缓存
为了优化网络性能,可以调整 Linux 系统的 TCP 缓存大小。默认情况下,系统的 TCP 缓存大小较小,可以通过以下命令进行调优:
sudo sysctl -w net.core.rmem_max=26214400
sudo sysctl -w net.core.wmem_max=26214400
sudo sysctl -w net.ipv4.tcp_rmem="10240 87380 12582912"
sudo sysctl -w net.ipv4.tcp_wmem="10240 87380 12582912"
这些命令调整了接收和发送的 TCP 缓存大小,可以提高高延迟、高带宽网络中的传输速度。
5.2 开启 TCP Fast Open
TCP Fast Open 是一种新的 TCP 协议扩展,允许客户端在连接握手时就开始发送数据,从而减少延迟。可以通过以下命令开启 TCP Fast Open:
sudo sysctl -w net.ipv4.tcp_fastopen=3
将这个配置写入 /etc/sysctl.conf 以在系统重启后保持设置:
echo "net.ipv4.tcp_fastopen=3" | sudo tee -a /etc/sysctl.conf

6. 使用 perf 进行性能分析
perf 是一个功能强大的 Linux 性能分析工具,它可以帮助你定位性能瓶颈。以下是一个简单的使用示例:
- 安装
perf:
sudo apt install linux-tools-common linux-tools-generic
- 使用
perf来记录 CPU 性能数据:
perf record -a -g
- 分析性能报告:
perf report
perf 会生成
一份详细的报告,显示哪些函数或进程占用了最多的 CPU 资源,从而帮助你进行进一步的优化。

7. 结论
Linux 系统性能调优是一项复杂的任务,需要根据具体的工作负载和系统环境进行有针对性的优化。本文介绍了从 CPU、内存、磁盘 I/O 和网络四个方面进行性能调优的方法,并提供了一些实用的工具和配置建议。在实际操作中,性能调优不仅仅是调整参数,还需要持续监控系统性能,以确保优化效果持续有效。通过合理的调优,Linux 系统可以在高负载下保持高效、稳定的运行。

相关文章:
Linux系统性能调优技巧详解
Linux系统性能调优技巧详解 Linux 系统广泛应用于服务器、嵌入式设备以及开发工作站中,因此对其进行性能调优是保障系统高效运行的关键之一。性能调优不仅可以提高系统的响应速度,还能有效优化资源使用,避免瓶颈。在这篇文章中,我…...
MFC工控项目实例之十九手动测试界面输出信号切换
承接专栏《MFC工控项目实例之十八手动测试界面输入信号实时检测》 根据板卡设置界面组合框选项设定的输出信号,通过读取文件中保存的键值,用单选按钮切换输出信号接通、关闭。 1、在Data_1.h文件中添加代码 CString COMB_Data_O_1[]{"夹紧",&…...
数据结构——栈的基本操作
前言 介绍 🍃数据结构专区:数据结构 参考 该部分知识参考于《数据结构(C语言版 第2版)》55 ~ 59页 🌈每一个清晨,都是世界对你说的最温柔的早安:ૢ(≧▽≦)و✨ 1、栈的基本概念 栈&#x…...
Chainlit集成LlamaIndex实现知识库高级检索(组合对象检索)
检索原理 对象组合索引的原理 是利用IndexNode索引节点,将两个不同类型的检索器作为节点对象,使用 SummaryIndex (它可以用来构建一个包含多个索引节点的索引结构。这种索引通常用于从多个不同的数据源或索引方法中汇总信息,并能…...
万界星空科技铜拉丝行业MES系统,实现智能化转型
一、铜拉丝行业生产管理的难点主要体现在以下几个方面: 1、标准严格:铜线产品对质量的要求极高,特别是在电气性能、导电性、耐腐蚀性等方面,任何微小的瑕疵都可能影响产品的使用效果和安全性。 2、过程监控:生产过程…...
ECCV 2024 现场:参会者付高价、跨万里,却无法入场?
ECCV(European Conference on Computer Vision,欧洲计算机视觉国际会议)是计算机视觉领域的重要国际会议之一,与CVPR和ICCV并称为计算机视觉的三大顶级会议。 ECCV2024是该系列会议的第18届会议,2024年9月29日至10月4…...
使用rsync+jenkins实现服务自动部署全流程
项目背景:城市政务云服务器没有上k8s,所有后端服务都是原始方式部署启动 (java -jar xxx.jar),那么有没有方式简化部署难度,实现自动部署?当然是有的,下面详细介绍(以Cen…...
python 实现decision tree决策树算法
decision tree决策树算法介绍 决策树算法(Decision Tree Algorithm)是一种基于输入特征对实例进行分类的树结构模型,主要用于分类和回归任务。其基本原理是根据训练数据的特征属性和类别标签之间的关系,生成一个能够对新样本进行…...
前端大模型入门:实战篇之Vue3+Antdv+transformers+本地模型实现增强搜索
本文将之前的文章,实现一个场景的实战应用,包含代码等内容。利用纯前端实现增强的列表搜索,抛弃字符串匹配,目标是使用番茄关键字可以搜索到西红柿 1 准备工作 1.1 了解llm和web开发 web端的ai开发参考 前端大模型入门ÿ…...
《向量数据库指南》——Fivetran 的 Partner SDK:构建自定义连接器和目标
哈哈,说到 Fivetran 的 Partner SDK,这可真是个好东西啊!作为向量数据库领域的“老司机”,我今天就来给大家详细讲讲这个 SDK 的厉害之处,以及如何用它来构建自定义连接器和目标,实现与 Fivetran 自动化数据移动平台的无缝集成。 一、Fivetran Partner SDK:开启自定义连…...
微信小程序的 button 标签的边框如何去除?
目录 问题描述: 问题原因: 解决办法: 方案一 方案二 问题描述: 实际开发中会发现这个 button 自带有样式,当背景颜色设置为白色的时候还有一个黑色的边框,刚开始那个边框怎么都去不掉 无法去除的边框…...
20240926 关于Goland处理wsl-GOROOT原理猜测
GOROOT的原理 go sdk与java jdk类似,是go的编译工具链的集合。 在windows上,我们通过在系统环境变量中添加GOROOT并设置为go sdk地址,使得命令行可以访问到go sdk并执行go test、build等命令,这样设置的变量是全局生效的&#x…...
Anki 学习日记 - 卡片模版 - 单选ABCD(纯操作)
摘要:在不懂前端语言的情况下自定义卡片模版,卡片模版的字段 安装(官网):Anki - powerful, intelligent flashcards (ankiweb.net) 一、在哪能修改卡片模版 管理笔记模板 - > 添加 -> 问答题 -> 设置名称 二…...
钉钉x昇腾:用AI一体机撬动企业数字资产智能化
“走红”近两年后,大模型正在加速走进千行万业。 由于大模型的主要模态是文字和图片,恰好是数字化办公最基础的内容要素,办公于是成了离AI最近的场景。 公文写作、表格生成、提炼大纲、文本翻译、代码润色、数据统计、智能问答……越来越多…...
【C/C++】 秋招常考面试题最全总结(让你有一种相见恨晚的感觉)
目录 1.C程序编译链接过程 2.浅拷贝和move有区别吗 3.深拷贝和浅拷贝的区别 4.空类的大小 5.类的继承有几种方式,区别是什么? 六、extern 关键字的作用 七、static关键字的作用 八、指针和引用的区别 九、C内存分配方式 十、结构体对齐…...
CSS面试真题 part1
CSS面试真题 part1 1、说说你对盒子模型的理解2、谈谈你对BFC的理解3、什么是响应式设计?响应式设计的基本原理是什么?如何做?4、元素水平垂直居中的方法有哪些?如果元素不定宽高呢?5、如何实现两栏布局,右…...
针对考研的C语言学习(定制化快速掌握重点5)
顺序表 特点: 写代码主要就是增删改查!!! 写代码的边界性非常重要以及考研插入和删除的位置都是从1开始,而数组下标是从0开始 【注】下标和位置的关系 线性表最重要的是插入和删除会涉及边界问题以及判断是否合法 …...
构建高效房屋租赁系统:Spring Boot应用
1 绪论 1.1 研究背景 中国的科技的不断进步,计算机发展也慢慢的越来越成熟,人们对计算机也是越来越更加的依赖,科研、教育慢慢用于计算机进行管理。从第一台计算机的产生,到现在计算机已经发展到我们无法想象。给我们的生活改变很…...
学习单片机编程和硬件设计步骤
学习单片机编程和硬件设计可以分为几个步骤: 理解基本概念:首先需要了解单片机的基本概念、硬件结构和工作原理 。 选择开发平台:选择一个合适的单片机系列作为起点,如Arduino、ESP8266/ESP32或STM32系列 。 准备工具和环境&…...
.net Framework 4.6 WebAPI 使用Hangfire
C# 使用 Hangfire 第一章 .net Framework 4.6 WebAPI 使用Hangfire 文章目录 C# 使用 Hangfire前言一、hangfire是什么?二、hangfire的特点三、.net Framework 中hangfire的使用方法第一步:创建WebAPI控制器第二步:添加nuget包第三步 创建startup类新建项目startup类Startu…...
后端程序员必看:3-6个月从0到1转型高薪AI应用
本文针对传统后端程序员想转型AI应用开发的焦虑,提出了一条省时、高薪、稳定的转型路线。文章指出,转型AI应用开发的核心是复用后端优势,走“后端AI集成”的复合型路线,而非死磕底层算法。文章详细规划了3-6个月的转型路线&#x…...
3D Tiles Tools终极指南:如何快速掌握3D模型格式转换与优化
3D Tiles Tools终极指南:如何快速掌握3D模型格式转换与优化 【免费下载链接】3d-tiles-tools 项目地址: https://gitcode.com/gh_mirrors/3d/3d-tiles-tools 在3D地理空间数据可视化领域,3D Tiles Tools是一套功能强大的开源工具集,专…...
iOSDeviceSupport终极指南:如何快速解决Xcode设备支持文件缺失问题
iOSDeviceSupport终极指南:如何快速解决Xcode设备支持文件缺失问题 【免费下载链接】iOSDeviceSupport All versions of iOS Device Support 项目地址: https://gitcode.com/gh_mirrors/ios/iOSDeviceSupport 你是否曾经在iOS开发中遇到过这样的困扰…...
Loop习惯追踪:从零开始构建你的长期习惯养成系统
Loop习惯追踪:从零开始构建你的长期习惯养成系统 【免费下载链接】uhabits Loop Habit Tracker, a mobile app for creating and maintaining long-term positive habits 项目地址: https://gitcode.com/gh_mirrors/uh/uhabits 你是否曾下定决心培养一个好习…...
InferenceX:大模型高效推理引擎核心原理与生产部署实战
1. 项目概述:从模型训练到高效推理的最后一公里如果你在AI领域,特别是大模型应用开发上投入过精力,那么对“InferenceX”这个名字可能不会感到陌生。它不是一个全新的训练框架,也不是一个模型仓库,而是精准地瞄准了当前…...
快速排序:核心知识点全解析
一、快速排序 核心所有知识点1. 核心思想分治 挖坑 / 左右双指针 基准值 pivot选一个基准值 pivot把数组划分成:左边 ≤ pivot,右边 ≥ pivot递归对左、右子区间重复划分区间长度为 1 时终止,整体有序2. 时间复杂度平均:\(O(n\l…...
艾尔登法环:黑夜君临2026.5.12最新破解版免费下载 一键转存 永久更新 (看到速转存 资源随时走丢)
下载链接 这是一篇关于《艾尔登法环:黑夜君临》(Elden Ring: Nightreign)的深度解析文章。 破碎边缘的守望:解析《艾尔登法环:黑夜君临》的架构与演变 在动作角色扮演游戏的版图上,《艾尔登法环》无疑是一…...
从MWC 2016看5G与物联网:技术演进、产业博弈与生态构建
1. 从巴塞罗那看2016年移动通信的十字路口 时间回到2016年初,如果你身处通信行业,那么2月底的日程表上,巴塞罗那的“移动世界大会”绝对是一个绕不开的焦点。那不是一个普通的展会,更像是一个行业在技术迭代、市场转型和地缘政治多…...
String、StringBuilder、StringBuffer 学习与深入
1 学习的知识是什么 String:字符串,一旦创建里面的内容就不可变,每次使用拼接都创建一个新的对象而原有的对象依旧存在。 StringBuilder:可变字符串线程不安全,…...
全球化技术团队协作:跨越文化差异的沟通与管理实践
1. 从“理所当然”到“文化自觉”:全球化职场的思维转型在电子设计自动化(EDA)和半导体行业摸爬滚打了十几年,我参与过跨国项目,也带过分布在全球各地的团队。一个深刻的体会是,我们这些搞技术的࿰…...
