Linux性能优化实战学习笔记:第五十五讲

1、上节回顾

上一节,咱们一块儿学习了,应用程序监控的基本思路,先简单回顾一下。应用程序的监控,能够分为指标监控和日志监控两大块。ios

指标监控,主要是对必定时间段内的性能指标进行测量,而后再经过时间序列的方式,进行处理、存储和告警。算法

而日志监控,则能够提供更详细的上下文信息,一般经过 ELK 技术栈,来进行收集、索引和图形化展现。数据库

在跨多个不一样应用的复杂业务场景中,你还能够构建全链路跟踪系统。这样,你就能够动态跟踪调用链中各个组件的性能,生成整个应用的调用拓扑图,从而加快定位复杂应用的性能问题。缓存

不过,若是你收到监控系统的告警,发现系统资源或者应用程序出现性能瓶颈,又该如何进一步分析它的根源呢?今天,我就分别从系统资源瓶颈和应用程序瓶颈这两个角度,带你一块儿来看
看,性能分析的通常步骤。性能优化

2、系统资源瓶颈

首先来看系统资源的瓶颈,这也是最为常见的性能问题。服务器

在系统监控的综合思路篇中,我曾经介绍过,系统资源的瓶颈,能够经过 USE 法,即使用率、饱和度以及错误数这三类指标来衡量。系统的资源,能够分为硬件资源和软件资源两类。网络

  1. 如 CPU、内存、磁盘和文件系统以及网络等,都是最多见的硬件资源。
  2. 而文件描述符数、链接跟踪数、套接字缓冲区大小等,则是典型的软件资源。

这样,在你收到监控系统告警时,就能够对照这些资源列表,再根据指标的不一样来进行定位。多线程

实际上,我们专栏前四大模块的核心,正是学会去分析这些资源瓶颈致使的性能问题。因此,当你碰到了系统资源的性能瓶颈时,前面模块的全部思路、方法以及工具,都彻底能够照用。并发

接下来,我就从 CPU 性能、内存性能、磁盘和文件系统 I/O 性能以及网络性能等四个方面,带你回顾一下它们的分析步骤tcp

3、CPU 性能分析

第一种最多见的系统资源是 CPU。关于 CPU 的性能分析方法,我在如何迅速分析出系统 CPU的瓶颈中,已经为你整理了一个迅速分析 CPU 性能瓶颈的思路。

还记得这张图吗?利用 top、vmstat、pidstat、strace 以及 perf 等几个最多见的工具,获取CPU 性能指标后,再结合进程与 CPU 的工做原理,就能够迅速定位出 CPU 性能瓶颈的来源。

实际上,top、pidstat、vmstat 这类工具所汇报的 CPU 性能指标,都源自 /proc 文件系统(好比 /proc/loadavg、/proc/stat、/proc/softirqs 等)。这些指标,都应该经过监控系统监控起
来。虽然并不是全部指标都须要报警,但这些指标却能够加快性能问题的定位分析。

好比说,当你收到系统的用户 CPU 使用率太高告警时,从监控系统中直接查询到,致使 CPU 使用率太高的进程;而后再登陆到进程所在的 Linux 服务器中,分析该进程的行为。

你可使用 strace,查看进程的系统调用汇总;也可使用 perf 等工具,找出进程的热点函数;甚至还可使用动态追踪的方法,来观察进程的当前执行过程,直到肯定瓶颈的根源。

4、内存性能分析

说完了 CPU 的性能分析,再来看看第二种系统资源,即内存。关于内存性能的分析方法,我在如何“快准狠”找到系统内存的问题中,也已经为你整理了一个快速分析的思路。

下面这张图,就是一个迅速定位内存瓶颈的流程。咱们能够经过 free 和 vmstat 输出的性能指标,确认内存瓶颈;而后,再根据内存问题的类型,进一步分析内存的使用、分配、泄漏以及缓
存等,最后找出问题的来源。

同 CPU 性能同样,不少内存的性能指标,也来源于 /proc 文件系统(好比/proc/meminfo、/proc/slabinfo 等),它们也都应该经过监控系统监控起来。这样,当你收到
内存告警时,就能够从监控系统中,直接获得上图中的各项性能指标,从而加快性能问题的定位过程。

好比说,当你收到内存不足的告警时,首先能够从监控系统中。找出占用内存最多的几个进程。而后,再根据这些进程的内存占用历史,观察是否存在内存泄漏问题。肯定出最可疑的进程后,
再登陆到进程所在的 Linux 服务器中,分析该进程的内存空间或者内存分配,最后弄清楚进程为何会占用大量内存。

5、磁盘和文件系统 I/O 性能分析

接下来,咱们再来看第三种系统资源,即磁盘和文件系统的 I/O。关于磁盘和文件系统的 I/O 性能分析方法,我在如何迅速分析出系统 I/O 的瓶颈中也已经为你整理了一个快速分析的思路。

咱们来看下面这张图。当你使用 iostat ,发现磁盘 I/O 存在性能瓶颈(好比 I/O 使用率太高、响应时间过长或者等待队列长度忽然增大等)后,能够再经过 pidstat、 vmstat 等,确认 I/O
的来源。接着,再根据来源的不一样,进一步分析文件系统和磁盘的使用率、缓存以及进程的 I/O等,从而揪出 I/O 问题的真凶

同 CPU 和内存性能相似,不少磁盘和文件系统的性能指标,也来源于 /proc 和 /sys 文件系统(好比 /proc/diskstats、/sys/block/sda/stat 等)。天然,它们也应该经过监控系统监控起
来。这样,当你收到 I/O 性能告警时,就能够从监控系统中,直接获得上图中的各项性能指标,从而加快性能定位的过程。

好比说,当你发现某块磁盘的 I/O 使用率为 100% 时,首先能够从监控系统中。找出 I/O 最多的进程。而后,再登陆到进程所在的 Linux 服务器中,借助 strace、lsof、perf 等工具,分析该进
程的 I/O 行为。最后,再结合应用程序的原理,找出大量 I/O 的缘由。

6、网络性能分析

最后的网络性能,其实包含两类资源,即网络接口和内核资源。在网络性能优化的几个思路中,我也曾提到过,网络性能的分析,要从 Linux 网络协议栈的原理来切入。下面这张图,就是
Linux 网络协议栈的基本原理,包括应用层、套机字接口、传输层、网络层以及链路层等。

而要分析网络的性能,天然也是要从这几个协议层入手,经过使用率、饱和度以及错误数这几类性能指标,观察是否存在性能问题。好比 :

  1. 在链路层,能够从网络接口的吞吐量、丢包、错误以及软中断和网络功能卸载等角度分析;
  2. 在网络层,能够从路由、分片、叠加网络等角度进行分析;
  3. 在传输层,能够从 TCP、UDP 的协议原理出发,从链接数、吞吐量、延迟、重传等角度进行分析;
  4. 在应用层,能够从应用层协议(如 HTTP 和 DNS)、请求数(QPS)、套接字缓存等角度进行分析。

同前面几种资源相似,网络的性能指标也都来源于内核,包括 /proc 文件系统(如/proc/net)、网络接口以及 conntrack 等内核模块。这些指标一样须要被监控系统监控。这
样,当你收到网络告警时,就能够从监控系统中,查询这些协议层的各项性能指标,从而更快定位出性能问题。

好比,当你收到网络不通的告警时,就能够从监控系统中,查找各个协议层的丢包指标,确认丢包所在的协议层。而后,从监控系统的数据中,确认网络带宽、缓冲区、链接跟踪数等软硬件,
是否存在性能瓶颈。最后,再登陆到发生问题的 Linux 服务器中,借助 netstat、tcpdump、bcc 等工具,分析网络的收发数据,而且结合内核中的网络选项以及 TCP 等网络协议的原理,找出问题的来源。

7、应用程序瓶颈

除了以上这些来自网络资源的瓶颈外,还有不少瓶颈,其实直接来自应用程序。好比,最典型的应用程序性能问题,就是吞吐量(并发请求数)降低、错误率升高以及响应时间增大。

不过,在我看来,这些应用程序性能问题虽然各类各样,但就其本质来源,实际上只有三种,也就是资源瓶颈、依赖服务瓶颈以及应用自身的瓶颈。

第一种资源瓶颈,其实仍是指刚才提到的 CPU、内存、磁盘和文件系统 I/O、网络以及内核资源等各种软硬件资源出现了瓶颈,从而致使应用程序的运行受限。对于这种状况,咱们就能够用前
面系统资源瓶颈模块提到的各类方法来分析。

第二种依赖服务的瓶颈,也就是诸如数据库、分布式缓存、中间件等应用程序,直接或者间接调用的服务出现了性能问题,从而致使应用程序的响应变慢,或者错误率升高。这说白了就是跨应
用的性能问题,使用全链路跟踪系统,就能够帮你快速定位这类问题的根源。

最后一种,应用程序自身的性能问题,包括了多线程处理不当、死锁、业务算法的复杂度太高等等。对于这类问题,在咱们前面讲过的应用程序指标监控以及日志监控中,观察关键环节的耗时
和内部执行过程当中的错误,就能够帮你缩小问题的范围。

不过,因为这是应用程序内部的状态,外部一般不能直接获取详细的性能数据,因此就须要应用程序在设计和开发时,就提供出这些指标,以便监控系统能够了解应用程序的内部运行状态。

若是这些手段事后仍是没法找出瓶颈,你还能够用系统资源模块提到的各种进程分析工具,来进行分析定位。好比:

  1. 你能够用 strace,观察系统调用;
  2. 使用 perf 和火焰图,分析热点函数;
  3. 甚至使用动态追踪技术,来分析进程的执行状态。

固然,系统资源和应用程序原本就是相互影响、相辅相成的一个总体。实际上,不少资源瓶颈,也是应用程序自身运行致使的。好比,进程的内存泄漏,会致使系统内存不足;进程过多的 I/O
请求,会拖慢整个系统的 I/O 请求等。

因此,不少状况下,资源瓶颈和应用自身瓶颈,其实都是同一个问题致使的,并不须要咱们重复分析。

8、小结

今天,我带你从系统资源瓶颈和应用程序瓶颈这两个角度,梳理了性能问题分析的通常步骤。

从系统资源瓶颈的角度来讲,USE 法是最为有效的方法,即从使用率、饱和度以及错误数这三个方面,来分析 CPU、内存、磁盘和文件系统 I/O、网络以及内核资源限制等各种软硬件资源。关
于这些资源的分析方法,我也带你一块儿回顾了我们专栏前面几大模块的分析套路。

从应用程序瓶颈的角度来讲,咱们能够把性能问题的来源,分为资源瓶颈、依赖服务瓶颈以及应用自身瓶颈这三类。

  1. 资源瓶颈跟系统资源瓶颈,本质是同样的。
  2. 依赖服务瓶颈,你可使用全链路跟踪系统进行定位。
  3. 而应用自身的问题,你能够经过系统调用、热点函数,或者应用自身的指标监控以及日志监控等,进行分析定位。

值得注意的是,虽然我把瓶颈分为了系统和应用两个角度,但在实际运行时,这二者每每是相辅相成、相互影响的。系统是应用的运行环境,系统的瓶颈会致使应用的性能降低;而应用的不合理设计,也会引起系统资源的瓶颈。咱们作性能分析,就是要结合应用程序和操做系统的原理,揪出引起问题的真凶。

相关文章
相关标签/搜索