千家信息网

操作系统性能监控之CPU监控

发表于:2024-11-30 作者:千家信息网编辑
千家信息网最后更新 2024年11月30日,操作系统性能监控服务端程序除了应用本身性能外,依赖与服务器本身的性能,今天学习了如何监测服务器性能。包括:CPU、内存、网络IO和磁盘使用率。今天先看看如何监测CPU。CPU监控CPU使用率vmsta
千家信息网最后更新 2024年11月30日操作系统性能监控之CPU监控

操作系统性能监控

服务端程序除了应用本身性能外,依赖与服务器本身的性能,今天学习了如何监测服务器性能。包括:CPU、内存、网络IO和磁盘使用率。

今天先看看如何监测CPU。

CPU监控

CPU使用率

vmstat命令

oot@SSP001:[/root]vmstatprocs -----------memory---------- ---swap-- -----io---- --system-- -----cpu----- r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st 0  0  79484 90085784 591052 79229448    0    0     0     6    0    0  1  1 97  0  0

其中CPU部分代表cpu的监测数据。
具体含义如下:

名称含义英文
us用户态CPU时间(百分比)user time
sy系统态CPU时间(百分比)system time
id空闲CPU时间(百分比)Time spent idle
wa等待IO的CPU时间Time spent waiting for IO
st不知道什么鬼,忽略Time stolen from a virtual machine. Prior to Linux 2.6.11, unknown.

参数中需要注意的是如果wa很高,代表IO等待时间很高,有可能是磁盘IO出现瓶颈。

mpstat

[root@Hwseeker-Adx02 ~]# mpstat  -P ALL 10 1Linux 2.6.32-573.3.1.el6.x86_64 (Hwseeker-Adx02)    2018年01月23日     _x86_64_    (24 CPU)16时45分03秒  CPU    %usr   %nice    %sys %iowait    %irq   %soft  %steal  %guest   %idle16时45分13秒  all    1.96    0.00    0.68    0.00    0.00    0.15    0.00    0.00   97.2116时45分13秒    0    8.32    0.00    1.83    0.00    0.00    0.20    0.00    0.00   89.6416时45分13秒    1    2.21    0.00    0.60    0.00    0.00    0.20    0.00    0.00   96.9816时45分13秒    2    2.23    0.00    0.61    0.00    0.00    0.30    0.00    0.00   96.8616时45分13秒    3    3.25    0.00    1.32    0.00    0.00    0.61    0.00    0.00   94.8216时45分13秒    4    0.20    0.00    0.20    0.00    0.00    0.00    0.00    0.00   99.6016时45分13秒    5    6.38    0.00    2.13    0.00    0.00    1.01    0.00    0.00   90.4916时45分13秒    6    1.20    0.00    0.40    0.00    0.00    0.00    0.00    0.00   98.4016时45分13秒    7    0.60    0.00    0.60    0.00    0.00    0.10    0.00    0.00   98.6916时45分13秒    8    0.60    0.00    0.40    0.00    0.00    0.00    0.00    0.00   98.9916时45分13秒    9    0.20    0.00    0.10    0.00    0.00    0.00    0.00    0.00   99.7016时45分13秒   10    1.10    0.00    0.20    0.00    0.00    0.00    0.00    0.00   98.7016时45分13秒   11    0.50    0.00    0.40    0.00    0.00    0.00    0.00    0.00   99.1016时45分13秒   12    2.92    0.00    0.70    0.00    0.00    0.10    0.00    0.00   96.2716时45分13秒   13    0.50    0.00    0.50    0.00    0.00    0.10    0.00    0.00   98.9016时45分13秒   14    6.90    0.00    1.93    0.00    0.00    0.61    0.00    0.00   90.5716时45分13秒   15    5.99    0.00    1.42    0.00    0.00    0.61    0.00    0.00   91.9816时45分13秒   16    0.10    0.00    0.10    0.00    0.00    0.00    0.00    0.00   99.8016时45分13秒   17    0.71    0.00    0.81    0.00    0.00    0.10    0.00    0.00   98.3816时45分13秒   18    0.40    0.00    0.30    0.00    0.00    0.00    0.00    0.00   99.3016时45分13秒   19    0.60    0.00    0.50    0.00    0.00    0.00    0.00    0.00   98.8916时45分13秒   20    0.30    0.00    0.40    0.00    0.00    0.00    0.00    0.00   99.3016时45分13秒   21    0.20    0.00    0.30    0.00    0.00    0.00    0.00    0.00   99.5016时45分13秒   22    0.30    0.00    0.30    0.00    0.00    0.00    0.00    0.00   99.4016时45分13秒   23    1.31    0.00    0.40    0.00    0.00    0.00    0.00    0.00   98.29

mpstat可以查看每个cpu的状态,可以发现应用中一些线程比其他线程消耗了更多CPU周期,还是所有线程基本平分CPU周期。如果是所有线程平分CPU周期,代表应用扩展性很好。
mpstat命令具体使用方法可以自行百度。这里我们需要关注的还是%usr/%sys/%iowait这几个字段。

top命令

[root@Hwseeker-Adx02 ~]# toptop - 16:51:46 up 762 days, 16:33,  1 user,  load average: 0.65, 0.40, 0.29Tasks: 598 total,   1 running, 596 sleeping,   0 stopped,   1 zombieCpu(s):  1.6%us,  0.7%sy,  0.0%ni, 97.5%id,  0.0%wa,  0.0%hi,  0.1%si,  0.0%stMem:  132119192k total, 130669000k used,  1450192k free,  1157188k buffersSwap: 131071996k total,  4017704k used, 127054292k free, 88117860k cached  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND36660 root      20   0 24.3g 4.7g  13m S 16.8  3.7   4401:08 java36888 root      20   0 24.4g 4.7g  13m S 14.8  3.8   4332:33 java52318 root      20   0 2353m 1.0g  39m S  5.9  0.8  67399:27 firefox 5631 root      20   0 1252m  29m 1924 S  2.0  0.0  22434:02 main21114 root      20   0  150m  13m 1364 S  2.0  0.0 664:08.76 redis-server

top命令不仅能监控用户态CPU、系统态cpu、空闲率,而且还会按照cpu使用率把进程列出来,使用起来很方便。

CPU程序调度队列

运行队列中是哪些正在等待可用CPU的轻量级进程。对于判断CPU是否满负荷运转很有帮助。

对于调度队列长度,该如何处理呢?

  1. 在很长一段时间里,运行队列的长度一直都超过cpu的核数的一倍,就需要关注,但不需要立即采取行动。
  2. 如果长时间是cpu核数的3~4倍或更高,就需要立即采取行动。
    解决方法:
    1.增加cpu
    2.分析运行中的应用,改进使用率。如减少垃圾收集的频度。

    vmstat

    oot@SSP001:[/root]vmstatprocs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st0  0  79484 90085784 591052 79229448    0    0     0     6    0    0  1  1 97  0  0

    其中r列就是队列长度。

本博文内容为《Java性能优化权威指南》的读书笔记整理而来

时间 性能 队列 使用率 命令 线程 应用 系统 监控 代表 周期 百分 百分比 长度 服务 监测 运行 含义 方法 服务器 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 深圳金鸢软件开发有限公司 网络安全 教育目的 pbp天恒软件开发 网络安全和信息化四个强化 方舟手游进别人的服务器 sql添加数据库失败 北京回收服务器硬盘云主机 阿里云oracle数据库 上海停车系统软件开发报价 海康威视服务器如何远程下载 中心软件开发中心地址 网络技术特色 无忧行软件开发 杭州义牛网络技术有限公司首页 云汉芯城互联网科技怎么样 数据库模块难点解决方法 珠海万重山网络技术有限公司 360是不是国家网络安全部队 各网络安全设备原理 数据库的新建用户名和密码 it软件开发外包合同范本 惠州科信网络技术企业 医院数据库的作用是什么 app显示服务器忙稍后再试 接入公安部数据库 未来网络安全保卫工作发展趋势 从数据库导出某各表 拓普互联网科技有限公司 软件开发的步骤与工具 世界电脑版不用正版登录的服务器
0