`

你需要知道的 16 个 Linux 服务器监控命令

阅读更多
转自: http://blog.jobbole.com/15430/?utm_source=rss&utm_medium=rss&utm_campaign=%25e4%25bd%25a0%25e9%259c%2580%25e8%25a6%2581%25e7%259f%25a5%25e9%2581%2593%25e7%259a%2584-16-%25e4%25b8%25aa-linux-%25e6%259c%258d%25e5%258a%25a1%25e5%2599%25a8%25e7%259b%2591%25e6%258e%25a7%25e5%2591%25bd%25e4%25bb%25a4

如果你想知道你的服务器正在做干什么,你就需要了解一些基本的命令,一旦你精通了这些命令,那你就是一个 专业的 Linux 系统管理员。
有些 Linux 发行版会提供 GUI 程序来进行系统的监控,例如 SUSE Linux 就有一个非常棒而且专业的工具 YaST,KDE 的 KDE System Guard 同样很出色。当然,要使用这些工具,你必须在服务器跟前进行操作,而且这些 GUI 的程序占用了很多系统资源,所以说,尽管 GUI 用来做基本的服务器健康状态监测挺好,但如果你想知道真正发生什么,请关掉 GUI 开始命令行之旅吧。
你应该只在需要的时候去启动 GUI ,不用的时候关掉它。如果要让服务器保持最佳性能,你应该将 Linux 服务器的运行级别 runlevel 设置为 3 ,就是控制台模式,当你需要图形化桌面的时候使用 startx 命令来启动它。
如果你的服务器启动后就直接进入图形界面,你需要修改配置 /etc/inittab 找到 initdefault 一样,将 id:5:initdefault 修改为 id:3:initdefault。
如果你没找到 /etc/inittab 文件,那就创建一个新的,文件内容增加 id:3 这么一行。这样下次服务器启动的时候就不会进入图形界面。如果你不想等到服务器重启的时候才生效,你可以执行 init 3 这个命令。
一旦你的服务器是在控制台模式下运行,你就可以开始我们接下来的内容。
iostat
iostat 命令用来显示存储子系统的详细信息,通常用它来监控磁盘 I/O 的情况。要特别注意 iostat 统计结果中的 %iowait 值,太大了表明你的系统存储子系统性能低下。
meminfo 和 free
Meminfo 可让你获取内存的详细信息,你可以使用 cat 和 grep 命令来显示 meminfo 信息:
1
cat /proc/meminfo
另外你可以使用 free 命令来显示动态的内存使用信息,free 只是给你大概的内存信息,而 meminfo 提供的信息更加详细。例如在 oschina 上的 free 命令执行结果:

mpstat
mpstat mpstat是MultiProcessor Statistics的缩写,是实时系统监控工具。其报告与CPU的一些统计信息,这些信息存放在/proc/stat文件中。在多CPUs系统里,其不但能查看所有CPU的平均状况信息,而且能够查看特定CPU的信息。
再来看看 oschina 上的 mpstat 命令执行结果:

netstat
Netstat 和 ps 命令类似,是 Linux 管理员基本上每天都会用的工具,它显示了大量跟网络相关的信息,例如 socket 的使用、路由、接口、协议、网络等等,下面是一些常用的参数:
1
2
3
4
-a Show all socket information
-r Show routing information
-i Show network interface statistics
-s Show network protocol statistics
nmon
Nmon, 是 Nigel’s Monitor 的缩写,是一个使用很普遍的开源工具,用以监控 Linux 系统的性能。Nmon 监控多个子系统的性能数据,例如处理器的使用率、内存使用率、队列、磁盘I/O统计、网络I/O统计、内存页处理和进程信息。Nmon 也提供了一个图形化的工具:

要运行 nmon,你可以在命令行中启动它,然后选择要监控的子系统,这些子系统都对应有一个快捷键,例如输入 c 可查看 CPU 信息,m用于查看内存,d用来查看磁盘信息等,你也可以使用 -f 命令将 nmon 的执行结果保存到一个 CSV 文件中,便于日后分析。
在每日的监控工作中,我发现 nmon 是我最常用的工具。
pmap
pmap 命令用来报告每个进程占用内存的详细情况,可用来看是否有进程超支了,该命令需要进程 id 作为参数。
ps 和 pstree
ps 和 pstree 命令是 Linux 系统管理员最好的朋友,都可以用来列表正在运行的所有进程。ps 告诉你每个进程占用的内存和 CPU 处理时间,而 pstree 显示的信息没那么详细,但它以树形结构显示进程之间的依赖关系,包括子进程信息。一旦发现某个进程有问题,你可以使用 kill 来杀掉它。
sar
sar 程序是系统监控工具里的瑞士军刀。该程序包含三个工具:sar 用来显示数据,sa1 和 sa2 用来收集数据并保存。sar 可用来显示 CPU 使用率、内存页数据、网络 I/O 和传输统计、进程创建活动和磁盘设备的活动详情。sar 和 nmon 最大的不同就是 sar 跟适合用作长期的监控,而 nmon 可以让你快速的了解系统当前状态。
strace
strace 经常被认为是程序员调试的工具,但不止如此。它可以记录进程进行系统调用的详情,因此它也是一个非常好的诊断工具,例如你可以使用它来找出某个程序正在打开某个配置文件。
Strace 也有一个缺陷,但它在跟踪某个进程时会让该进程的性能变得非常差,因此请谨慎使用。
tcpdump
Tcpdump 是一个简单、可靠的网络监控工具,用来做基本的协议分析,看看那些进程在使用网络以及如何使用网络。当然,如果你要获取跟详细的信息,你应该使用 Wireshark (下面我们会介绍).
top
top 命令显示当前的活动进程,默认它是按消耗 CPU 的厉害程度进行排序,每5秒钟刷新一次列表,你也可以选择不同的排序方式,例如 m 是按内存占用方式进行排序的快捷键。
uptime
uptime 命令告诉你这台服务器从开机启动到现在已经运行了多长时间了。同时也包含了从启动到现在服务器的平均负载情况,看看 oschina 的数据:

我已经忘了上次是为什么重启机器了,好像是换了个机柜。
vmstat
你可以使用 vmstat 来监控虚拟内存,一般 Linux 上的开发者喜欢使用虚拟内存来获得最佳的存储性能。该命令报告关于内核线程、虚拟内存、磁盘、陷阱和 CPU 活动的统计信息。由 vmstat 命令生成的报告可以用于平衡系统负载活动。系统范围内的这些统计信息(所有的处理器中)都计算出以百分比表示的平均值,或者计算其总和。
在 oschina 上执行 vmstat 的结果:

Wireshark
Wireshark, 前身是 Ethereal ,是一个网络协议检测程序,让您经由程序抓取运行的网站的相关资讯,包括每一封包流向及其内容、资讯可依操作系统语系看出,方便查看、监控TCP session动态等等.

这里罗列的是大多数最有价值的 Linux 监控程序,当然,你可能还会使用其他的工具,不妨跟大家分享下。
分享到:
评论

相关推荐

    你需要知道的16个Linux服务器监控命令

    如果你想知道你的服务器正在做干什么,你就需要了解一些基本的命令,一旦你精通了这些 命令,那你就是一个 专业的 Linux 系统管理员。 有些 Linux 发行版会提供 GUI 程序来进行系统的监控,例如 SUSE Linux 就有一个...

    你需要知道的 16 个 Linux 服务器监控命令.pdf

    本文将介绍16个必备的Linux监控命令,帮助你深入了解服务器的运行状态。 1. **iostat**:此命令用于查看存储子系统的性能,特别是磁盘I/O。关注%iowait字段,如果值过高,可能表明磁盘I/O存在瓶颈。 2. **meminfo ...

    16 个大师最爱用的Linux 服务器监控命令

    16 个大师最爱用的Linux 服务器监控命令

    Linux服务器的16个监控命令.pdf

    本文将详细介绍16个Linux服务器监控命令,它们分别涉及存储、内存、处理器、网络等多个方面。 首先,关于服务器运行级别,运行级别(runlevel)是Linux系统的一种启动方式,用于确定系统启动时运行的服务和守护进程。...

    16个不可不知的Linux服务器监控命令.docx

    16个不可不知的Linux服务器监控命令.docx

    16个必备Linux服务器监控命令

    Linux 服务器监控命令 Linux 服务器管理员需要掌握的 16 个必备监控命令,通过这些命令可以了解服务器的详细情况,从而确保服务器的性能和安全。 iostat 命令详细地显示了存储子系统方面的情况,能够监控存储子...

    lr 如何监控 linux服务器

    通过以上步骤,你可以在LoadRunner测试过程中实时监控Linux服务器的CPU使用率、内存占用、磁盘I/O等关键性能指标,从而更好地理解和优化系统的性能表现。这种监控能力对于识别潜在问题、预防系统崩溃以及优化系统...

    Linux服务器维护常用命令

    ### Linux服务器维护常用命令知识点详解 #### 一、概述 在Linux服务器的日常维护工作中,掌握一系列关键命令是必不可少的技能。这些命令可以帮助系统管理员高效地监控、管理和维护服务器环境。根据提供的信息,我们...

    Linux性能监控命令

    Linux 性能监控命令 Linux 性能监控命令是 Linux 操作系统中用于监控和优化系统性能的命令集。这些命令可以帮助系统管理员和开发者监控系统的性能、 troubleshooting 故障、优化系统配置等。 1. Crond 命令 Crond...

    Linux服务器查看性能命令

    本文将详细介绍 Linux 服务器性能查看命令,包括查看操作系统及硬件信息、CPU 信息、Mem 信息、磁盘信息、网卡信息、主板信息、机器所有硬件信息等多个方面。 1. 查看服务器操作系统及硬件信息(压力测试前) 在...

    服务器性能监控(主机、内存、磁盘、cpu)

    1、需要配置一台FTP服务器,可以LINUX服务器中搭建一个FTP服务即可。 2、监控的服务器需要与FTP服务器网络连通。 3、需要修改LINUX脚本中的FTP服务器地址,用户名和密码。 4、需要在每台...

    jmeter+linux资源监控

    这个错误与JMeter和Linux资源监控的主题直接关联性不大,但在执行自动化测试或数据抓取时可能会遇到,解决方法包括检查网络连接、验证URL的有效性以及确保目标服务器没有阻止请求。 总的来说,结合JMeter和Linux...

    开源的Linux服务器监控,数据采集,Linux服务器运维的有力助手

    开源的Linux服务器监控工具提供了丰富的功能,帮助我们实时掌握服务器的运行状态,及时发现并解决潜在问题,提高系统的稳定性和安全性。本文将详细探讨标题和描述中提到的知识点,并围绕"XMonitor客户端"这一开源...

    Linux远程监控设计与实现

    【Linux远程监控设计与实现】这篇文章主要探讨了如何在Linux环境下设计和实现一个远程监控系统,以实时监控服务器的CPU、内存和硬盘资源使用情况。该系统旨在提高网络管理的安全性和便利性。 1. **引言**: - 在...

    LR监控linux服务器配置

    LR监控linux服务器配置

    linux系统的监控命令

    本文将详细讲解两个常用的Linux监控命令:`top`和`vmstat`。 首先,`top`命令是Linux中一个强大的实时系统监控工具,它能显示系统中各个进程的资源占用状况,包括CPU使用率、内存使用情况、进程状态等。`top`命令的...

    loadrunner 监控Linux资源服务开启

    1. **配置监控参数**:在LoadRunner Controller中,你需要定义监控的目标系统(即Linux服务器),并设置需要监控的资源类型和阈值。这可以通过创建新的监控场景来实现。 2. **添加监控代理**:LoadRunner支持多种...

    基于windows平台的linux服务器批量管理可视化工具

    使用此工具可以同时对 成千上万 多台linux服务器同时进行命令下发 文件上传 文件下载功能 由于对多台linux服务器进行管理需要维护大量密码 本工具也可通过配置private key进行服务器的统一管理 由于工具的功能正在...

Global site tag (gtag.js) - Google Analytics