下图1为 Linux 性能优化排查工具的总结

图1

诊断 CPU 工具

查看 CPU 核数

总核数 = 物理CPU个数 X 每颗物理CPU的核数 
总逻辑CPU数 = 物理CPU个数 X 每颗物理CPU的核数 X 超线程数

查看物理CPU个数 
cat /proc/cpuinfo| grep "physical id"| sort| uniq| wc -l

查看每个物理CPU中core的个数(即核数) 
cat /proc/cpuinfo| grep "cpu cores"| uniq

查看逻辑CPU的个数 
cat /proc/cpuinfo| grep "processor"| wc -l 
或者 top 后按 1,第三行开始数有几个CPU 就是几个逻辑CPU 如图2只有一个逻辑CPU0

图2

图2

top

top命令可以实时动态地查看系统的整体运行情况,是一个综合了多方信息监测系统性能和运行信息的实用工具。通过top命令所提供的互动式界面,用热键可以管理。

语法

top [选项]

选项

-b:以批处理模式操作; 
-c:显示完整的治命令; 
-d:屏幕刷新间隔时间; 
-I:忽略失效过程; 
-s:保密模式; 
-S:累积模式; 
-i<时间>:设置间隔时间; 
-u<用户名>:指定用户名; 
-p<进程号>:指定进程; 
-n<次数>:循环显示的次数。

图3

图3


在 Linux 命令终端输入 top 后屏幕将会显示如图3显示的信息,那么这些信息显示的是什么意思呢?下面将针对每行信息进行回答。

如下图4所示,红框区域所显示信息为系统统计信息,黄框显示信息为进程信息 图4

图4

系统统计信息

第一行:top - 02:17:40 up 53 days, 5:15, 1 user, load average: 0.02, 0.04, 0.01

  • 02:17:40 表示系统当前时间。
  • up 53 days, 5:15 up 是 uptime 的意思表示当前系统运行的时长,图4 系统运行时长为 53天5小时15分钟。
  • 1 user 就很简单了表示当前只有一个用户连接。
  • load average 是看性能的时候比较重要的一个指标表示系统负载,也就是任务队列的平均长度,后面三个数分别表示1分钟、5分钟、15分钟。如果是单cpu当这个值超过1的时候需要检查系统是否出现异常,这个值当超过5的时候基本上系统已经处于死机状态。

关于 load average 推荐阅读阮一峰的文章:http://www.ruanyifeng.com/blog/2011/07/linux_load_average_explained.html

第二行:Tasks: 119 total, 1 running, 118 sleeping, 0 stopped, 0 zombie

用于统计系统上进程信息,119 total 表示系统中总进程数为119,1 running 表示当前正在运行的进程有一个, 118 sleeping 表示当前休眠的进程有 118 个, 0 stopped 表示当前停止的进程, o zombie 表示僵尸进程

第三行:Cpu(s): 0.3%us, 0.7%sy, 0.0%ni, 99.0%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st

这里默认显示所有 CPU 的总状态,按下 1 键即可显示所有逻辑 CPU 状态。

  • us(userspace) 表示用户空间占用CPU时间百分比。
  • sy 表示内核空间占用CPU时间百分比。
  • ni 明白 ni 之前需要先了解一个知识点,Linux 系统通过 nice 值来设置进程优先级 nice 值越高优先级越低,nice 可以被手动设置, ni 在这里就表示被手动设置过 nice 值的进程占用 CPU 时间百分比。
  • id 就是 idle 表示 CPU 空闲时间的百分比,
  • wa 就是 waiting 的意思表示 CPU 在等待 I/O 上花费的时间百分比,
  • hi 全称是 hardware interrupts 表示 CPU 处理硬件中断花费的时间百分比,比如在键盘上敲一个键。
  • si 全称是 software interrupts 软件通过发出特殊 CPU 指令中断,表示 CPU 在处理软件中断花费的时间百分比。
  • st 全称是 steal time(被偷走的时间) CPU 花费在虚拟机上的时间百分比。

第四行:Mem: 520132k total, 254340k used, 265792k free, 24916k buffers

Mem 就是内存信息,其他都是字面意思

  • total — 物理内存总量
  • used — 使用中的内存总量
  • free — 空闲内存总量
  • buffers — 缓存的内存量

第五行:Swap: 135164k total, 7176k used, 127988k free, 105748k cached

swap交换分区信息

  • total — 交换区总量
  • used — 使用的交换区总量
  • free — 空闲交换区总量
  • cached — 缓冲的交换区总量

系统进程信息

  • PID — 进程id
  • USER — 进程所有者
  • PR — 进程优先级
  • NI — nice值。负值表示高优先级,正值表示低优先级
  • VIRT — 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
  • RES — 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
  • SHR — 共享内存大小,单位kb
  • S — 进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程
  • %CPU — 上次更新到现在的CPU时间占用百分比
  • %MEM — 进程使用的物理内存百分比
  • TIME+ — 进程使用的CPU时间总计,单位1/100秒
  • COMMAND — 进程名称(命令名/命令行)

排查技巧

通过 top –H -p 查看运行时间较长线程

参考资料:
https://www.ibm.com/developerworks/cn/java/j-lo-performance-tuning-practice/index.html
https://www.cnblogs.com/peida/archive/2012/12/24/2831353.html
https://www.booleanworld.com/guide-linux-top-command/
http://www.blogjava.net/hankchen/archive/2012/05/09/377735.html

Linux 性能优化排查工具的更多相关文章

  1. Linux性能优化-平均负载

    Linux性能优化-平均负载 目录 Linux性能优化-平均负载 平均负载的含义 平均负载为多少时合理 平均负载与 CPU 使用率 平均负载案例分析 场景一:CPU 密集型进程 场景二:I/O 密集型 ...

  2. Linux 性能优化之 IO 子系统 系列 图

    http://blog.sina.com.cn/s/articlelist_1029388674_11_1.html Linux 性能优化之 IO 子系统(一) 本文介绍了对 Linux IO 子系统 ...

  3. 如何学习Linux性能优化?

    如何学习Linux性能优化? 你是否也曾跟我一样,看了很多书.学了很多 Linux 性能工具,但在面对 Linux 性能问题时,还是束手无策?实际上,性能分析和优化始终是大多数软件工程师的一个痛点.但 ...

  4. Linux 性能測试工具

    Linux 性能測试工具 linux performance 查看系统配置 查看CPU信息 lscpu Architecture: x86_64 CPU op-mode(s): 32-bit, 64- ...

  5. Linux性能分析命令工具汇总

    转自:http://rdc.hundsun.com/portal/article/731.html?ref=myread 出于对Linux操作系统的兴趣,以及对底层知识的强烈欲望,因此整理了这篇文章. ...

  6. Linux性能优化从入门到实战:01 Linux性能优化学习路线

      我通过阅读各种相关书籍,从操作系统原理.到 Linux内核,再到硬件驱动程序等等.   把观察到的性能问题跟系统原理关联起来,特别是把系统从应用程序.库函数.系统调用.再到内核和硬件等不同的层级贯 ...

  7. Android 性能优化之工具和优化点总结

    Android性能优化学习 最近公司主抓性能优化工作,借此春风也学习到了许多Android性能优化方面的知识.由于组内队友的给力,优化的成果也是比较喜人.同时也学习和实践了不少知识,特此记录. 1.性 ...

  8. 转载linux性能调优工具

    Linux 大牛,Netflix 高级性能架构师 Brendan Gregg 更新 Linux 性能调优工具,各种资源应有尽有,大量干货,强烈建议收藏.

  9. linux ---性能监控(工具)

    linux服务器性能监控-nmon Nmon 是一个分析aix和linux性能的免费工具,出自IBM,其采集的数据通过nmon_analyser生成报表 一.下载 官网下载地址 百度网盘 二.运行和使 ...

随机推荐

  1. Linux实现免密码登录

    一.验证ssh远程登录,未作免密处理的两台机器,登录时,是需要输入密码的 二.本地系统执行 ssh-keygen -t rsa 命令,生成密钥文件 三.在相应的目录下查看生成的密钥文件,其中:id_r ...

  2. JavaScript—图片与base64编码互相转换

    图片转换为base64编码 <input type = "file" id = "file" onchange="popFileName(thi ...

  3. hisi mmz模块驱动讲解

    一.概述 如图所示,在海思平台上将内存分为两个部分:os内存和mmz内存.os内存指:由linux操作系统管理的内存:mmz内存:由mmz驱动模块进行管理供媒体业务单独使用的内存,在驱动加载时可以指定 ...

  4. JavaScript显式类型转换与隐式类型转换

    隐式类型转换 四则运算 判断语句 toString 在 JavaScript 中声明变量不需指定类型,对变量赋值也没有类型检查,同时还允许隐式类型转换. 这些特征说明 JavaScript 属于弱类型 ...

  5. linux学习(二)linux系统的安装

    Linux 安装 本章节我们将为大家介绍 Linux 的安装,安装步骤比较繁琐,现在其实云服务器挺普遍的,价格也便宜,如果直接不想搭建,也可以直接买一台学习用用,参考各大云服务器比较. 本章节以 ce ...

  6. Requests text乱码

    都在推荐用Requests库,而不是Urllib,但是读取网页的时候中文会出现乱码. 分析: r = requests.get(“http://www.baidu.com“) **r.text返回的是 ...

  7. 20191102 「HZOJ NOIP2019 Round #12」20191102模拟

    先开坑. md原题写挂我也真是... 100+20+10 白夜 打表大法吼 显然,不在环上的点对答案的贡献是 \((k-cycle)^{k-1}\) . 打表得到环上的递推式,矩阵一下乘起来就好了. ...

  8. 使用threaddump-analyzer 快速查看jvm thread 状态信息

    日常开发中,我们可以需要通过thread dump 查看线程信息,比如锁,spotify 团队提供了一个web 界面,很方便 以下是简单使用,同时添加了docker 支持 添加docker 支持 cl ...

  9. 【2019.7.25 NOIP模拟赛 T3】树(tree)(dfs序列上开线段树)

    没有换根操作 考虑如果没有换根操作,我们该怎么做. 我们可以求出原树的\(dfs\)序列,然后开线段树维护. 对于修改操作,我们可以倍增求\(LCA\),然后在线段树上修改子树内的值. 对于询问操作, ...

  10. rest-framework框架——版本

    一.DRF版本控制介绍 随着项目更新,版本会越来越多,不能新的版本出现,旧版本就不再使用维护了.因此不同的版本会有不同的处理,且接口会返回不同的信息. API版本控制允许我们在不同的客户端之间更改行为 ...