热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

linux查看网络io负载,linux硬件资源问题排查:cpu负载、内存使用情况、磁盘空间、磁盘IO...

在使用过程中之前正常的功能,突然无法使用,性能变慢,通常都是资源消耗问题,资源消耗可以从以下几个方面去排查。对于已经安装硬件

在使用过程中之前正常的功能,突然无法使用,性能变慢,通常都是资源消耗问题,资源消耗可以从以下几个方面去排查。对于已经安装硬件资源监控软件(zabbix)的环境,直接使用硬件资源监控软件(zabbix),检查服务器的资源消耗情况,在没有安装zabbix的环境,主要排查的资源包括CPU负载、内存使用情况、磁盘空间、磁盘IO等。

1.1.1    cpu负载

cpu负载就是cpu在一段时间内正在处理以及等待cpu处理的进程数之和的统计信息,也就是cpu使用队列的长度统计信息,这个数字越小越好。

使用top指令将会输出如下结果

load average代表CPU的平均负载值,示例中的load average: 1.30, 1.27,1.28分别表示当前CPU在1分钟、5分钟和15分钟内的平均负载。对于单核cpu,一旦大于1,就说明job得不到及时调度,系统性能将会受到影响。对于2核心来说,该值大于2才说明cpu忙不过来。

在top指令输出结果后,输入P,将进程按%cpu降序排列,查看哪些进程在大量占用cpu,输入M,将进程按%MEM降序排列,查看哪些进程在大量占用内存。

1.1.2    内存使用情况

使用free -h查看内存使用情况。

# free -h

total usedfree shared buff/cache available

Mem: 15G 12G 295M 38M2.8G 2.6G

Swap:7.9G 416M 7.5G

total表示系统总的可用物理内存大小,used表示已经使用的物理内存大小,available可以被 应用程序 使用的物理内存大小,当可使用的物理内存大小较小时,结合top指令,查看哪些应用程序占用的大量内存。

1.1.3    磁盘空间

使用df -h查看系统的磁盘使用情况。

# df -h

文件系统 容量 已用 可用 已用%挂载点/dev/sda2 50G 24G 27G 47% /devtmpfs7.8G 0 7.8G 0% /dev

tmpfs7.8G 28K 7.8G 1% /dev/shm

tmpfs7.8G 37M 7.8G 1% /run

tmpfs7.8G 0 7.8G 0% /sys/fs/cgroup/dev/sdb2 40G 4.8G 36G 12% /var/scs/dev/sdc2 30G 20G 11G 64% /home/dev/sda1 494M 208M 287M 43% /boot/dev/sdc1 249G 108G 142G 44% /home/sdc/dev/sdb1 239G 133G 107G 56% /home/sdb/dev/sda5 220G 101G 120G 46% /home/sda

tmpfs1.6G 4.0K 1.6G 1% /run/user/42tmpfs1.6G 32K 1.6G 1% /run/user/0

对于磁盘使用情况,主要关注已用%,已用%大于80%后要开始清理无效日志、不在使用的安装包等。

已用%较大的挂载点,使用du -sh 挂载点/*,查看挂载点内个文件、目录的实际大小。

# du -sh /home/*20K /home/bats

0 /home/data

127M /home/dba

85M /home/dba1.5.5

9.5G /home/dbus

23M /home/dbus_processor

4.0M /home/hcloud

65M /home/kafka

13M /home/log.tmp

188K /home/lost+found

93M /home/ltest

1.1.4    磁盘IO

使用iostat -x 5查看磁盘IO使用情况。

# iostat -x 5Linux3.10.0-957.5.1.el7.x86_64 (node9) 2020年04月09日 _x86_64_ (4CPU)

avg-cpu: %user %nice %system %iowait %steal %idle27.61 0.03 3.72 0.12 0.00 68.52Device: rrqm/s wrqm/s r/s w/s rkB/s wkB/s avgrq-sz avgqu-sz await r_await w_await svctm %util

sdb0.01 0.05 5.46 6.23 166.86 351.76 88.76 0.04 3.02 2.45 3.52 0.31 0.36sda2.28 5.02 1.24 28.60 36.80 658.85 46.63 0.01 0.24 3.89 0.08 0.12 0.35sdc0.01 0.03 0.33 1.07 2.61 8.68 16.14 0.00 0.62 2.50 0.03 0.43 0.06avg-cpu: %user %nice %system %iowait %steal %idle3.32 0.00 4.50 0.00 0.00 92.18Device: rrqm/s wrqm/s r/s w/s rkB/s wkB/s avgrq-sz avgqu-sz await r_await w_await svctm %util

sdb0.00 0.00 0.00 3.60 0.00 56.00 31.11 0.00 0.00 0.00 0.00 0.00 0.00sda0.00 0.20 0.00 32.40 0.00 669.60 41.33 0.00 0.06 0.00 0.06 0.04 0.14sdc0.00 0.00 0.00 0.60 0.00 2.40 8.00 0.00 0.00 0.00 0.00 0.00 0.00avg-cpu: %user %nice %system %iowait %steal %idle4.18 0.00 5.25 0.00 0.00 90.57Device: rrqm/s wrqm/s r/s w/s rkB/s wkB/s avgrq-sz avgqu-sz await r_await w_await svctm %util

sdb0.00 0.20 0.00 7.80 0.00 138.40 35.49 0.00 0.05 0.00 0.05 0.05 0.04sda0.00 0.00 0.00 29.40 0.00 952.00 64.76 0.00 0.07 0.00 0.07 0.03 0.08sdc0.00 0.00 0.00 1.40 0.00 12.80 18.29 0.00 0.00 0.00 0.00 0.00 0.00

重点关注参数:

1、iowait% 表示CPU等待IO时间占整个CPU周期的百分比,如果iowait值超过50%,或者明显大于%system、%user以及%idle,表示IO可能存在问题。

2、avgqu-sz 表示磁盘IO队列长度,即IO等待个数。

3、await 表示每次IO请求等待时间,包括等待时间和处理时间

4、svctm 表示每次IO请求处理的时间

5、%util 表示磁盘忙碌情况,一般该值超过80%表示该磁盘可能处于繁忙状态。

pidstat -d 3命令查看进程占用磁盘IO的情况

kB_rd/s: 每秒进程从磁盘读取的数据量(以kB为单位)

kB_wr/s: 每秒进程向磁盘写的数据量(以kB为单位)

# pidstat -d 3 3Linux3.10.0-957.5.1.el7.x86_64 (node9) 2020年04月09日 _x86_64_ (4CPU)

13时35分30秒 UID PID kB_rd/s kB_wr/s kB_ccwr/s Command

13时35分33秒0 5159 0.00 1.29 0.00dockerd

13时35分33秒0 5174 0.00 45.31 0.00loop0

13时35分33秒0 5456 0.00 1.29 0.00rsyslogd

13时35分33秒0 6379 0.00 2.59 0.00java

13时35分33秒0 7791 0.00 2.59 0.00java

13时35分33秒0 10411 0.00 1.29 0.00java

13时35分33秒27 15611 0.00 132.04 0.00mysqld

13时35分33秒0 26538 0.00 1.29 0.00java

13时35分33秒0 28097 0.00 1.29 0.00java

13时35分33秒0 30421 0.00 3.88 0.00java

13时35分33秒0 32541 0.00 1.29 0.00 java



推荐阅读
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • PatchODAX8: ... [详细]
  • systemd-nspawn可以创建最轻量级的容器(ns的意思就是namespace),本文的实验平台是Ubuntu16.04,x86_64机器。本文的目的是:在Ubuntu中用syst ... [详细]
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 本文介绍了一种轻巧方便的工具——集算器,通过使用集算器可以将文本日志变成结构化数据,然后可以使用SQL式查询。集算器利用集算语言的优点,将日志内容结构化为数据表结构,SPL支持直接对结构化的文件进行SQL查询,不再需要安装配置第三方数据库软件。本文还详细介绍了具体的实施过程。 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了软件测试知识点之数据库压力测试方法小结相关的知识,希望对你有一定的参考价值。 ... [详细]
  • Centos7搭建ELK(Elasticsearch、Logstash、Kibana)教程及注意事项
    本文介绍了在Centos7上搭建ELK(Elasticsearch、Logstash、Kibana)的详细步骤,包括下载安装包、安装Elasticsearch、创建用户、修改配置文件等。同时提供了使用华为镜像站下载安装包的方法,并强调了保证版本一致的重要性。 ... [详细]
  • 微软评估和规划(MAP)的工具包介绍及应用实验手册
    本文介绍了微软评估和规划(MAP)的工具包,该工具包是一个无代理工具,旨在简化和精简通过网络范围内的自动发现和评估IT基础设施在多个方案规划进程。工具包支持库存和使用用于SQL Server和Windows Server迁移评估,以及评估服务器的信息最广泛使用微软的技术。此外,工具包还提供了服务器虚拟化方案,以帮助识别未被充分利用的资源和硬件需要成功巩固服务器使用微软的Hyper - V技术规格。 ... [详细]
  • Spring Batch中多线程配置及实现例子
    本文介绍了在Spring Batch中开启多线程的配置方法,包括设置线程数目和使用线程池。通过一个示例演示了如何实现多线程从数据库读取数据并输出。同时提到了在多线程情况下需要考虑Reader的线程安全问题,并提供了解决方法。 ... [详细]
  • SQL Server 内存中OLTP内部机制概述(一)
    内存中OLTP(项目名为“Hekaton”)是一个新的完全集成到SQLServer中的数据库引擎组件。它专为访问内存常驻数据的OLTP工作负荷而进行优化。内存中OLTP有助于OLT ... [详细]
  • 1.脚本功能1)自动替换jar包中的配置文件。2)自动备份老版本的Jar包3)自动判断是初次启动还是更新服务2.脚本准备进入ho ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了SpringCloudRibbon部分源码相关的知识,希望对你有一定的参考价值。1:ribbon是提供通过servi ... [详细]
  • 我一直都有记录信息的习惯,不知是从什么时候开始,大约是在工作后不久。如今还真有点庆幸从那时开始记了点东西,当然是电子版的,写 ... [详细]
author-avatar
秀珍冠秋晓雯
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有