用于资源分析的USE方法是什么?-创新互联

用于资源分析的USE方法

对于每种资源,检查:

我们提供的服务有:网站设计制作、网站设计、微信公众号开发、网站优化、网站认证、城关ssl等。为1000+企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的城关网站制作公司

1、Utilization 使用率

2、Saturation 饱和度

3、Errors错误

用于资源分析的USE方法是什么?

Linux 60秒分析

这个内容来自性能分析大神和Netflix性能工程团队

1、 uptime

2、 dmesg | tail

3、 vmstat 1

4、 mpstat -P ALL 1

5、 pidstat 1

6、 iostat -xz 1

7、 free -m

8、 sar -n DEV 1

9、 sar -n TCP,ETCP 1

10、 top

uptime

这是查看平均负载的快速方法,该平均负载指示要运行的任务(进程)的数量。在Linux系统上,这些数字包括要在CPU上运行的进程以及在不可中断I / O(通常是磁盘I / O)中阻塞的进程。这给出了资源负载(或需求)的高级概念,然后可以使用其他工具进一步探索。

首次响应问题时,可以检查平均负载,以查看问题是否仍然存在。在容错环境中,遇到性能问题的服务器可能会在您登录查看时自动从服务中删除。15分钟的平均负载过高,而1分钟的平均负载过低,则表明您登录得太迟而无法发现问题。

dmesg | tail

 [1880957.563150] perl invoked oom-killer: gfp_mask=0x280da, order=0, oom_score_adj=0
[...]
[1880957.563400] Out of memory: Kill process 18694 (perl) score 246 or sacrifice child
[1880957.563408] Killed process 18694 (perl) total-vm:1972392kB, anon-rss:1953348kB,
file-rss:0kB
[2320864.954447] TCP: Possible SYN flooding on port 7001. Dropping request.  Check
SNMP counters.

这将显示过去的10条系统消息(如果有的话),查找可能导致性能问题的错误。

上面的示例包括OOM killer和TCP SYN flooding造成的连接丢弃情况。TCP消息甚至指向您进行下一个分析区域:SNMP计数器。

vmstat 1

这是起源于BSD的虚拟内存统计工具,它还显示其他系统指标。

请注意,第一行数字是自启动以来的摘要(内存计数器除外)。

用于资源分析的USE方法是什么?

mpstat -P ALL 1

$ mpstat -P ALL 1
[...]
03:16:41 AM  CPU   %usr  %nice  %sys %iowait  %irq  %soft %steal %guest %gnice  %idle
03:16:42 AM  all  14.27   0.00  0.75    0.44  0.00   0.00   0.06   0.00   0.00  84.48
03:16:42 AM    0 100.00   0.00  0.00    0.00  0.00   0.00   0.00   0.00   0.00   0.00
03:16:42 AM    1   0.00   0.00  0.00    0.00  0.00   0.00   0.00   0.00   0.00 100.00
03:16:42 AM    2   8.08   0.00  0.00    0.00  0.00   0.00   0.00   0.00   0.00  91.92
03:16:42 AM    3  10.00   0.00  1.00    0.00  0.00   0.00   1.00   0.00   0.00  88.00
03:16:42 AM    4   1.01   0.00  0.00    0.00  0.00   0.00   0.00   0.00   0.00  98.99
03:16:42 AM    5   5.10   0.00  0.00    0.00  0.00   0.00   0.00   0.00   0.00  94.90
03:16:42 AM    6  11.00   0.00  0.00    0.00  0.00   0.00   0.00   0.00   0.00  89.00
03:16:42 AM    7  10.00   0.00  0.00    0.00  0.00   0.00   0.00   0.00   0.00  90.00
[...]

此命令显示按CPU时间划分成状态的时间。

输出显示了一个问题:CPU 0达到了100%的用户时间,这是单线程瓶颈的证据。

还需要注意到是否有iowait很高的情况出现。以及可以通过syscall和kernel tracing以及CPU分析来探索的%sys时间。

pidstat 1

pidstat(1)显示每个进程的CPU使用率。top(1)是用于此目的的流行工具;但是,pidstat(1)默认提供滚动输出,以便可以看到随时间的变化。

$ pidstat 1
Linux 4.13.0-19-generic (...)       08/04/2018     _x86_64_     (16 CPU)
 
03:20:47 AM   UID       PID    %usr %system  %guest    %CPU   CPU  Command
03:20:48 AM     0      1307    0.00    0.98    0.00    0.98     8  irqbalance
03:20:48 AM    33     12178    4.90    0.00    0.00    4.90     4  java
03:20:48 AM    33     12569  476.47   24.51    0.00  500.98     0  java
03:20:48 AM     0    130249    0.98    0.98    0.00    1.96     1  pidstat
 
03:20:48 AM   UID       PID    %usr %system  %guest    %CPU   CPU  Command
03:20:49 AM    33     12178    4.00    0.00    0.00    4.00     4  java
03:20:49 AM    33     12569  331.00   21.00    0.00  352.00     0  java
03:20:49 AM     0    129906    1.00    0.00    0.00    1.00     8  sshd
03:20:49 AM     0    130249    1.00    1.00    0.00    2.00     1  pidstat
03:20:49 AM   UID       PID    %usr %system  %guest    %CPU   CPU  Command
03:20:50 AM    33     12178    4.00    0.00    0.00    4.00     4  java
03:20:50 AM   113     12356    1.00    0.00    0.00    1.00    11  snmp-pass
03:20:50 AM    33     12569  210.00   13.00    0.00  223.00     0  java
03:20:50 AM     0    130249    1.00    0.00    0.00    1.00     1  pidstat
[...]

此输出表明Java进程每秒消耗的CPU数量是变化的。注意这些百分比是所有CPU的总和,所以500%等于五个CPU的100%。

iostat -xz 1

此工具显示存储设备I / O指标。每个磁盘设备的输出列都在此处用换行符表示,因此很难读取。

用于资源分析的USE方法是什么?

free -m

推荐使用 -w参数, 显示的更详细

sar -n DEV 1

sar工具具有用于不同度量标准组的多种模式。

在这里,我使用它来查看网络设备指标。检查接口吞吐量rxkB/s和txkB/s,以查看是否已达到任何限制。

图上可以看到 enp2s0f0的received接收到的流量在 985和 2817kb/s, sended发出的流量在 847.7和965.78kb/s的样子。

用于资源分析的USE方法是什么?

sar -n TCP,ETCP 1

现在,我们使用sar(1)查看TCP指标和TCP错误。要检查的列:

active/s:   每秒本地启动的TCP连接数(例如,通过connect()),主动对外发起连接(可以理解为client模式)

passive/s:每秒远程启动的TCP连接数(例如,通过accept()) ,被动接收外部连接请求(可以理解为server模式)

retrans/s:每秒TCP重传的次数

主动和被动连接计数对于表征工作负载很有用。重新传输是网络或远程主机问题的迹象。

用于资源分析的USE方法是什么?

top

top命令,可以具备uptime的功能。此外还能按照cpu或者内存使用率排序、搜索指定进程。 总体而言,top命令具备很强大的process、cpu、mem瓶颈分析功能。这里不过多介绍。

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


标题名称:用于资源分析的USE方法是什么?-创新互联
URL分享:http://myzitong.com/article/didijj.html