linux之运维性能命令

在 Linux 系统中,有许多命令和工具可以帮助运维人员监控系统状态、性能以及定位问题。以下是一些常用的运维相关命令:

top: 如前所述,实时显示进程的资源占用情况。

htop: 类似于 top,但提供了一个更为用户友好的界面,支持颜色显示和滚动。

vmstat: 报告有关系统进程、内存、分页、块 IO、陷阱和 CPU 活动的信息。

iostat: 用于监控系统输入输出设备和分区的性能。

free: 显示内存的使用情况,包括物理内存、交换内存、缓冲和缓存。

df: 报告文件系统的磁盘空间使用情况。

du: 估算文件或目录所占用的磁盘空间。

lsof: 列出被进程打开的文件,可以用来查找哪个进程占用了磁盘空间或端口。

netstat: 显示网络连接、路由表、接口状态等网络相关信息。

ss: 与 netstat 类似,用来查看和监控网络连接。

tcpdump: 用于捕获和分析网络流量数据包。

nmap: 网络探测和安全扫描工具,用于探测网络上的主机和服务。

sar: 系统活动报告工具,可以回顾历史数据,了解系统在过去的表现。

mpstat: 报告 CPU 的使用情况。

pidstat: 报告特定 PID 或所有进程的 CPU、内存、I/O 等统计信息。

dmesg: 显示或控制内核环形缓冲区的内容,通常用于诊断硬件和驱动问题。

strace: 跟踪系统调用和信号,用于调试进程执行时的操作。

uptime: 显示系统已运行的时间以及平均负载。

ps: 报告当前系统的进程状态。

journalctl: 用于查询和显示从 systemd 日志开始以来的消息。

当 Linux 机器告警时,可以采取以下步骤快速定位问题:

查看系统日志:使用 dmesg 和 journalctl 检查是否有硬件故障或系统错误。

检查资源占用:使用 top 或 htop 确定哪些进程占用了过多的 CPU 或内存资源。

检查磁盘空间:使用 df 和 du 命令检查磁盘空间是否不足。

检查网络连接:使用 netstat、ss 和 nmap 查看网络连接和端口状态。

分析性能数据:使用 vmstat、iostat、mpstat 和 sar 进行更深入的性能分析。

监控进程和系统调用:使用 ps、pidstat 和 strace 监控特定进程的行为和系统调用。

检查内存使用:使用 free 和 vmstat 查看内存使用情况。

每个命令都有其详细的参数和用法,具体问题需要结合具体命令的输出和系统日志进行综合分析。在处理告警和问题时,可能需要根据具体情况组合使用这些命令

我会选择几个经常用于系统监控和故障排查的命令进行详细介绍:

top
top 命令是最常用的性能监控工具之一,它提供了一个实时更新的视图,显示系统中当前活动的进程以及它们对 CPU 和内存的使用情况。通过 top,你可以看到哪些进程占用了最多的资源,并可以进行进程管理,如改变优先级或终止进程。此外,它还显示了系统的负载平均值、正在运行的任务数量、CPU 状态等信息。

使用方法:

top
在 top 的界面中,你可以使用键盘命令进行交互,例如按 P 来按 CPU 使用率排序,按 M 按内存使用率排序,或者按 k 终止一个进程。

iostat
iostat 命令用于监视系统的 I/O 设备负载。它可以报告 CPU 统计和所有分区的输入/输出统计。这个工具对于检测系统的磁盘瓶颈非常有用。

使用方法:

iostat
你可以使用 -x 选项显示扩展的统计信息,或者使用 -c 仅显示 CPU 使用率,-d 仅显示磁盘使用情况,或是指定刷新间隔和次数,例如每 2 秒刷新一次,共刷新 5 次:

iostat -x 2 5
vmstat
vmstat (虚拟内存统计) 命令报告关于内核线程、虚拟内存、磁盘、陷阱和 CPU 活动的信息。这个工具对于理解系统上的工作负载特征非常有用。

使用方法:

vmstat 1
上述命令会每秒刷新一次输出。vmstat 的输出包括内存、交换、IO 和 CPU 部分的统计数字。

netstat
netstat 命令显示网络连接、路由表、接口统计信息等,是用于检查网络配置和活动的工具。

使用方法:

netstat -tulnp
选项 -tulnp 的含义如下:

-t: 显示 TCP 连接。

-u: 显示 UDP 连接。

-l: 仅显示监听套接字(通常用于查找运行的服务)。

-n: 显示 IP 地址而不是解析的主机名。

-p: 显示哪个进程正在使用套接字。

dmesg
dmesg 命令用于打印和控制内核环形缓冲区的消息,它通常用来检测硬件相关的问题和驱动程序消息。

使用方法:


使用 | less 可以让你方便地浏览消息。你也可以使用 -T 选项来查看人类可读的时间戳。

dmesg | less

lsof
lsof 命令列出当前系统打开文件的信息。由于在 Unix 和类 Unix 系统中,几乎一切都是文件(包括设备和网络套接字),lsof 是非常强大的排查工具。

使用方法:

lsof -i tcp:22


上述命令会列出所有使用 TCP 端口 22(通常是 SSH 服务)的进程。

文章来源:https://www.cnaaa.net,转载请注明出处:https://www.cnaaa.net/archives/12241

(0)
凯影的头像凯影
上一篇 2024年7月2日 下午4:37
下一篇 2024年7月3日 下午5:09

相关推荐

  • Kswapd0挖矿病毒查杀

    机器负载异常,刚重启过后CPU占用就快速上升至接近100%,且存在网络滥用的情况。使用top显示kswapd0进程疯狂占用cpu,google后有人说是linux虚拟内存的问题,但是系统刚开机,内存基本空闲,只是cpu疯狂被占用,这种说法明显有问题,继续排查后,我发现这个程序和一个名叫WachtdogsMiner的挖矿蠕虫和两个荷兰IP有关 查找病毒 使用t…

    2022年6月25日
    1.2K00
  • Nginx负载均衡介绍

    Nginx应用场景之一就是负载均衡。在访问量较多的时候,可以通过负载均衡,将多个请求分摊到多台服务器上,相当于把一台服务器需要承担的负载量交给多台服务器处理,进而提高系统的吞吐率;另外如果其中某一台服务器挂掉,其他服务器还可以正常提供服务,以此来提高系统的可伸缩性与可靠性 下图为负载均衡示例图,当用户请求发送后,首先发送到负载均衡服务器,而后由负载均衡服务器…

    2022年11月16日
    98400
  • 幻兽帕鲁服务器版本更新

    幻兽帕鲁服务器游戏怎么升级版本?自建幻兽帕鲁服务器进入Palworld游戏提示“您正尝试加入的比赛正在运行不兼容的游戏版本,请尝试升级游戏版本”什么原因?这是由于你的客户端和幻兽帕鲁服务器版本不匹配,如何解决?更新幻兽帕鲁服务器即可解决。 幻兽帕鲁进行一次更新,服务器也需要同步更新,才能继续游玩。 Linux服务器更新 1、使用如下命令,首先切换至root用…

    2024年2月4日
    2.0K00
  • 迁移到新服务器上的PHP网站,使用浏览器访问时提示“不支持MySQL”等信息,如何处理?

    问题描述 PHP网站(该网站需使用PHP执行程序代码)迁移到新服务器后,在使用浏览器访问时提示如下任意一种信息。 问题原因 因为MySQL扩展功能自PHP 5.5.0版本开始被废弃,并且从PHP 7.0.0版本开始被移除,当网站迁移到新服务器时一般会迁移到PHP 7.0.0及以上版本,由于网站迁移后的新服务器的PHP版本过高,网站程序无法再连接MySQL,导…

    2023年11月17日
    90000
  • Ansible 连接主机显示报错的处理方案

    一、在ansible安装完毕后一般需要以SSH的方式连接到需要进行管理的目标主机,一开始遇到了如下问题: 原因分析:没有在ansible管理节点(即安装ansible的节点)上添加目标节点(即需要管理的节点)的ssh认证信息。 解决步骤:1:管理节点生成SSH-KEY 成功后在~/.ssh/路径下将生成ssh密钥文件:id_rsa及id_rsa.pub2:添…

    2023年9月28日
    97300

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

在线咨询: QQ交谈

邮件:712342017@qq.com

工作时间:周一至周五,8:30-17:30,节假日休息

关注微信