zoukankan      html  css  js  c++  java
  • Linux性能测试工具

    Linux性能测试工具

    在测试中,我们不仅需要查看系统日志信息,而且还要使用大量的性能监测工具来关注某些地方,如内存、CPU等。在Linux系统中,所有的运行参数保存在虚拟目录/proc中,换句话说,我们使用的性能监控工具取到的数据值实际上就是源自于这个目录,下面就让我们了解一下这些常用的性能监控工具。

     

    工具

    功能描述

    uptime

    系统平均负载率

    dmesg

    硬件/系统信息

    top

    进程进行状态

    iostat

    CPU和磁盘平均使用率

    vmstat

    系统运行状态

    sar

    实时收集系统使用状态

       

    free

    内存使用率

    traffic-vis

    网络监控(只有SUSE有)

    pmap

    进程内存占用率

       

    ulimit

    系统资源使用限制

    mpstat

    多处理器使用率

    uptime

    uptime命令用于查看服务器运行了多长时间以及有多少个用户登录,快速获知服务器的负荷情况。
    uptime的输出包含一项内容是load average,显示了最近1,5,15分钟的负荷情况。它的值代表等待CPU处理的进程数,如果CPU没有时间处理这些进程,load average值会升高;反之则会降低。
    load average的最佳值是1,说明每个进程都可以马上处理并且没有CPU cycles被丢失。对于单CPU的机器,1或者2是可以接受的值;对于多路CPU的机器,load average值可能在8到10之间。
    以下是uptime的运行实例:
    9:24am 

     up  19:06,  1 user,  load average: 0.00, 0.00, 0.00

    也可以使用uptime命令来判断网络性能。例如,某个网络应用性能很低,通过运行uptime查看服务器的负荷是否很高,如果不是,那么问题应该是网络方面造成的。
    uptime对应的是/proc/loadavg和/proc/uptime两个文件

    dmesg

    dmesg命令主要用来显示内核信息。使用dmesg可以有效诊断机器硬件故障或者添加硬件出现的问题。
    另外,使用dmesg可以确定您的服务器安装了那些硬件。每次系统重启,系统都会检查所有硬件并将信息记录下来。执行/bin/dmesg命令可以查看该记录。

    *top*

    众所周知的top命令,显示处理器的活动状况。缺省情况下,显示占用CPU最多的任务,并且每隔5秒钟做一次刷新

    iostat

    执行iostat命令可以从系统启动之后的CPU平均时间,类似于uptime。除此之外,iostat还对创建一个服务器磁盘子系统的活动报告。该报告包含两部分:CPU使用情况和磁盘使用情况。CPU占用情况包括四块内容

    %user:显示user level (applications)时,CPU的占用情况。
    %nice:显示user level在nice priority时,CPU的占用情况。
    %sys:显示system level (kernel)时,CPU的占用情况。
    %idle: 显示CPU空闲时间所占比例。
    磁盘使用报告分成以下几个部分:
    Device: 块设备的名字
    tps: 该设备每秒I/O传输的次数。多个I/O请求可以组合为一个,每个I/O请求传输的字节数不同,因此可以将多个I/O请求合并为一个。
    Blk_read/s, Blk_wrtn/s: 表示从该设备每秒读写的数据块数量。块的大小可以不同,如1024, 2048 或 4048字节,这取决于partition的大小。
    对应的文件是/proc/stat,/proc/partitions,/proc/diskstats。

    vmstat

    vmstat提供了processes, memory, paging, block I/O, traps和CPU的活动状况。这个不多说了。地球人都知道。

    sar

    sar用于收集、报告或者保存系统活动信息。sar由三个应用组成:sar显示数据、sar1和sar2用于收集和保存数据。
    使用sar1和sar2,系统能够配置成自动抓取信息和日志,以备分析使用。
    从收集的信息中,可以得到详细的CPU使用情况(%user, %nice, %system, %idle)、内存页面调度、网络I/O、进程活动、块设备活动、以及interrupts/second

    free

    /bin/free命令显示所有空闲的和使用的内存数量,包括swap。同时也包含内核使用的缓存。

                        total            used       free     shared    buffers     cached

    Mem:        776492     263480     513012          0      52332     162504
    -/+ buffers/cache:      48644     727848
    Swap:      1044184          0    1044184

    Traffic-vis

    Traffic-vis是一套测定哪些主机在IP网进行通信、通信的目标主机以及传输的数据量。并输出纯文本、HTML或者GIF格式的报告。
    注:Traffic-vis仅仅适用于SUSE LINUX ENTERPRISE SERVER。
    如下命令用来收集网口eth0的信息:
    traffic-collector -i eth0 -s /root/output_traffic-collector
    可以使用killall命令来控制该进程。如果要将报告写入磁盘,可使用如下命令:
    killall -9 traffic-collector
    要停止对信息的收集,执行如下命令:killall -9 traffic-collector
    如要生成HTML格式的报告,显示传输的字节数,packets的记录、全部TCP连接请求和网络中每台服务器的信息,请运行命令:
    traffic-tohtml -i output_traffic-sort -o output_traffic-tohtml.html

    pmap

    pmap可以报告某个或多个进程的内存使用情况。使用pmap判断主机中哪个进程因占用过多内存导致内存瓶颈。
    $ pmap
    Usage: pmap [-x | -d] [-q] pid...
    -x  show details
    -d  show offset and device number
    -q  quiet; less header/footer info
    -V  show the version number

    ulimit

    ulimit内置在bash shell中,用来提供对shell和进程可用资源的控制,如 /etc/security/limits 文件所定义
    列出系统的资源限制:
    $ ulimit -a
    core file size          (blocks, -c) unlimited
    data seg size           (kbytes, -d) unlimited
    file size               (blocks, -f) unlimited
    pending signals                 (-i) 1024
    max locked memory       (kbytes, -l) 32
    max memory size         (kbytes, -m) unlimited
    open files                      (-n) 1024
    pipe size            (512 bytes, -p) 8
    POSIX message queues     (bytes, -q) 819200
    stack size              (kbytes, -s) 10240
    cpu time               (seconds, -t) unlimited
    max user processes              (-u) 139264
    virtual memory          (kbytes, -v) unlimited
    file locks                      (-x) unlimited
    -a 列出所有当前资源极限。
    -c 以 512 字节块为单位,指定核心转储的大小。
    -d 以 K 字节为单位指定数据区域的大小。
    -f 使用 Limit 参数时设定文件大小极限(以块计),或者在未指定参数时报告文件大小极限。缺省值为 -f 标志。
    -H 指定设置某个给定资源的硬极限。如果用户拥有 root 用户权限,可以增大硬极限。任何用户均可减少硬极限。
    -m 以 K 字节为单位指定物理存储器的大小。
    -n 指定一个进程可以拥有的文件描述符的数量的极限。
    -s 以 K 字节为单位指定堆栈的大小。
    -S 指定为给定的资源设置软极限。软极限可增大到硬极限的值。如果 -H 和 -S 标志均未指定,极限适用于以上二者。
    -t 指定每个进程所使用的秒数。

    mpstat

    mpstat用于报告多路CPU主机的每颗CPU活动情况,以及整个主机的CPU情况。
    例如,下边的命令可以隔2秒报告一次所有的处理器的活动情况,执行3次
    mpstat 2 3
    $ mpstat -P ALL 2 3
    Linux 2.6.9-52bs-4core (jx-testing-ps1114.jx.baidu.com)         03/21/2009

    12:53:28 AM  CPU   %user   %nice %system %iowait    %irq   %soft   %idle    intr/s
    12:53:30 AM  all    0.00    0.00    0.00    0.00    0.00    0.00  100.00   1005.50
    12:53:30 AM    0    0.00    0.00    0.00    0.00    0.00    0.00  100.00    125.00
    12:53:30 AM    1    0.00    0.00    0.00    0.00    0.00    0.00  100.00    130.50
    12:53:30 AM    2    0.00    0.00    0.00    0.00    0.00    0.00  100.00    125.00
    12:53:30 AM    3    0.00    0.00    0.00    0.00    0.00    0.00  100.00    125.00
    12:53:30 AM    4    0.00    0.00    0.00    0.00    0.00    0.00  100.00    125.00
    12:53:30 AM    5    0.00    0.00    0.00    0.00    0.00    0.00  100.00    125.00
    12:53:30 AM    6    0.00    0.00    0.00    0.00    0.00    0.00  100.00    125.00
    12:53:30 AM    7    0.00    0.00    0.00    0.00    0.00    0.00  100.00    125.00

  • 相关阅读:
    Django-session+CBV+ORM应用
    Django-session实现登陆
    Django-ORM-操作
    事件委托
    数组去重的方法
    闭包
    Javascript中继承
    函数调用的方式
    原型链的理解
    jsonp
  • 原文地址:https://www.cnblogs.com/argb/p/3448635.html
Copyright © 2011-2022 走看看