写点什么

三大套路带你通关 CPU 性能优化 | 极客时间

  • 2019-05-23
  • 本文字数:1605 字

    阅读完需:约 5 分钟

三大套路带你通关 CPU 性能优化 | 极客时间

无论是运维还是开发,和 Linux 打交道、在服务器上分析系统性能是每个技术人的日常。然而,性能优化也是软件系统中最有挑战的工作之一,就算看了很多资料和书籍,但一旦涉及到解决具体问题,还是难免困惑不已,比如,


  • 性能指标和性能分析工具那么多,我该怎么掌握和选择呢?

  • 即使会用指标和工具,又该如何快速定位性能瓶颈呢?

  • 找到性能瓶颈后,接下来该怎么优化呢?


以上三点,可以说是性能优化工作的重中之重。不过不要担心,凭借多年的性能优化经验,我总结出三大套路,带你攻下性能优化这一难关,分别是:


  • “性能指标/工具”指南;

  • “又快又准”的瓶颈定位套路;

  • 优化工作的必备思路。


当然,性能优化工作,离不开对系统原理的把握。从系统层面,我将其分为 CPU 性能、内存性能、I/O 性能和网络性能四大板块,并分别整理了对应的解决思路。今天我们就先以 CPU 性能为例,看看这些套路是怎么用的。

“指标/工具”指南

首先是对于性能指标和工具的掌握。我的经验是,从两个不同的维度来理解它们,做到活学活用,把性能指标和性能工具联系起来。


第一个维度,从 CPU 的性能指标出发。当你要查看某个性能指标时,要清楚地知道哪些工具可以做到。根据不同的性能指标,对提供指标的性能工具进行分类和理解。这样,在排查性能问题时,你就会知道什么工具可以提供你想要的指标,而不是毫无依据地挨个尝试,撞运气。



第二个维度,从工具出发。当你安装了某个工具后,要知道这个工具能提供哪些指标。这在实际环境,特别是生产环境中非常重要。因为在很多情况下,你并没有权限安装新的工具包,只能最大化地利用好系统中已经安装的工具,这就需要你对它们有足够的了解。


具体到每个工具的使用方法,一般都支持丰富的配置选项。这些配置选项你并不用背下来,只要知道有哪些工具、以及这些工具的基本功能是什么就够了。真正要用到的时候, 通过 man 命令,查询它们的使用手册就可以。


当然,这些常见指标和工具的对应关系,我制作了“指标-工具指南”和“工具-指标指南”两张图表,方便你梳理关系和理解记忆。


11 | 套路篇:如何迅速分析出系统CPU的瓶颈在哪里?

瓶颈定位套路

其次是快速定位性能瓶颈的套路。CPU 的性能指标比较多,而且它们之间并不是孤立的,很多指标间都有一定的关联。掌握不同指标之间的关联性,你就可以简化大多数问题了。


同样的,我制作了一张 CPU 性能指标和工具的关联图,列出了 top、vmstat 和 pidstat 分别提供的重要 CPU 指标,并用虚线表示关联关系,对应出了性能分析下一步的方向。


你可以保存这张图,作为 CPU 性能分析的思路图谱。从最核心的这几个工具开始,通过我提供的案例,自己在真实环境里实践,拿下它们。


优化必备思路

最后是具体的优化思路。这里我们首先要形成清晰的性能优化方法论。


从目的上说,我们解决性能问题是为了得到性能提升的效果,要明确并评估这种性能优化的效果,为此我总结了“性能评估三步走”,你可以参考使用:


  1. 确定性能的量化指标;

  2. 测试优化前的性能指标;

  3. 测试优化后的性能指标。


从操作上来说,多维度指标的选择、多性能问题的选择、多优化方法的选择,这三者都是我们考虑的重点。


12 | 套路篇:CPU 性能优化的几个思路


订阅专栏,了解更多”套路“


内存性能篇:21 | 套路篇:如何“快准狠”找到系统内存的问题?


I/O 性能篇:30 | 套路篇:如何迅速分析出系统I/O的瓶颈在哪里?


网络性能篇:36 | 套路篇:怎么评估系统的网络性能?


专栏简介


在专栏中,我结合自己多年的实战经验,以案例驱动的思路,为你讲解了 Linux 性能的基本指标、工具,以及相应的观测、分析和调优方法,让你学后可以立即应用在自己的优化工作中。针对评论区那些有代表性的问题,我专门设立了答疑篇章,为大家解惑的同时也可以为其他学习专栏的同学提供参考。


学完专栏后,你将获得:


  • Linux 常用的性能分析工具合集

  • 30 个 Linux 性能问题诊断思路

  • 读懂 CPU、内存、I/O 等指标

  • 5 个真实的线上环境分析案例


内容选自极客时间《Linux性能优化实战》专栏


2019-05-23 16:547184

评论

发布
暂无评论
发现更多内容

让企业内部开发游刃有余,平台工程到底是什么?

树上有只程序猿

DevOps 软件开发 平台工程

备份或同步数据?跨国大文件传输的不同需求与解决方案

镭速

大文件传输 跨国文件传输

中路对线发现正在攻防演练中投毒的红队大佬

墨菲安全

网络安全 npm 投毒 投毒分析

低代码系列——初步认识低代码

互联网工科生

软件开发 低代码 JNPF

生成式AI技术:引领未来内容创作

百度开发者中心

物联网, 云计算, 文心一言 人工智能、

解决跨时区跨语言的国外大文件传输问题

镭速

跨国传输大文件 传输大文件 国外大文件传输

科技前沿的助力:探索语音标注平台的奇迹

数据堂

开放网关架构演进

阿里技术

网关 开放网关

九科信息成功签约中交财资管理(香港)有限公司-境外银行账户可视化管控流程自动化系统项目

九科Ninetech

介绍一下我们的开源“充电之旅” - 两位新晋 Apache Flink Committer 专访

字节跳动云原生计算

flink 开源 字节跳动 流式计算

软件测试/测试开发丨Python 错误与异常 学习笔记

测试人

Python 程序员 软件测试 自动化测试 测试开发

人机协作的交融:语音标注平台的秘密

数据堂

​Kubernetes的演变:从etcd到分布式SQL的过渡

互联网工科生

Kubernetes etcd 部署

RocketMQ 5.0 架构解析:如何基于云原生架构支撑多元化场景

阿里巴巴云原生

阿里云 RocketMQ 云原生

技术分享| WebRTC之SDP详解

anyRTC开发者

WebRTC RTC sdp

校源行丨开放原子开源基金会赴苏州大学走访交流

开放原子开源基金会

开源

报名开启 | HarmonyOS第一课“营”在暑期系列直播

HarmonyOS开发者

HarmonyOS

和鲸 ModelWhale 与中科可控多款服务器完成适配认证,赋能中国云生态

ModelWhale

云原生 服务器 信创

关于云原生开源开发者沙龙「微服务X消息队列专场」的延期通知

阿里巴巴云原生

阿里云 微服务 云原生 消息队列

画质提升+带宽优化,小红书音视频团队端云结合超分落地实践

小红书技术REDtech

音视频 小红书

拯救开源:《网络韧性法案》即将带来的悲剧

开源雨林

开源 LICENSE

MySQL的Json类型字段IN查询分组和优化方法

北桥苏

MySQL SQL优化 虚拟字段

手把手带你玩转HetuEngine:资源规划与数据源对接

华为云开发者联盟

大数据 后端 华为云 华为云开发者联盟 企业号 8 月 PK 榜

SRE方法论之服务质量目标

不思jo

SRE

揭秘!CIPU最新秘密武器–弹性RDMA的技术解析与实践

阿里云弹性计算

小米交卷大模型,全新小爱同学实测来了

Openlab_cosmoplat

小米 大模型 小爱同学

借助 AI 工具,真的能成为 10x 工程师?

飞算JavaAI开发助手

生成式AI:人工智能新范式,引领生产力革命

百度开发者中心

#人工智能 文心一言

三大套路带你通关 CPU 性能优化 | 极客时间_硬件_倪朋飞_InfoQ精选文章