Linux优化必备:深入了解lmbench性能测试工具 (linux性能测试工具 lmbench)

随着Linux的广泛使用,性能优化变得越来越重要。在过去的几十年中,能够在Linux上使用的性能测试工具数量增加了很多。其中一个最强大的性能测试工具是lmbench。在本文中,我们将深入了解lmbench性能测试工具,了解如何使用它来评估和优化Linux系统的性能。

lmbench是一个性能测试套件,它被设计用于测试许多常见操作系统的性能。它的核心是一组基准测试,这些测试包括内存带宽测试、上下文切换测试、时间开销测试等。lmbench有两个主要的目标:之一个是提供一个统一的、易于使用的性能测试工具,第二个是提供一个标准化的测试框架,以便不同系统之间的比较。

lmbench包含了许多不同的基准测试,每个基准测试都有一个唯一的名称和一组参数。这些基准测试包括:

– bw_mem:测试内存带宽。

– lat_mem_rd:测试内存读取延迟。

– lat_ctx:测试进程上下文切换延迟。

– lat_syscall:测试系统调用延迟。

– pipe_ctx:测试进程间管道通信延迟。

– conn_udp:测试UDP网络连接延迟。

– tcp_lat:测试TCP网络连接延迟。

– tcp_bw:测试TCP网络带宽。

这只是lmbench中可用测试的一小部分。此外,每个基准测试还有许多不同的参数可以设置,以便更好地满足您的需求。

lmbench的输出非常详细,让用户能够深刻地了解Linux系统的性能表现。输出包括每个测试的平均值、标准差、最小值和更大值。此外,输出还包括有关应该特别注意的测试的重要信息。

在使用lmbench时,您需要确保在计算机上安装了它。安装lmbench可能会略微复杂,但通常只需要运行几个命令即可完成。在安装完成后,您可以使用命令行工具运行测试。最基本的命令如下:

“`

lmbench-run -f [test] [test options]

“`

该命令将运行所选测试,并将结果写入文件。您可以通过指定不同的测试和测试选项来测试不同的方面。例如,下面是一个测试内存带宽的例子:

“`

lmbench-run -f mem_bw_results bw_mem

“`

当测试完成后,您可以使用tools目录中的工具来分析结果。例如,可以使用结果分析器(yze)打开输出文件并查看结果。

相关问题拓展阅读:

Linux服务器硬件情况的查看

1、首先是对于CPU的说明

服务器CPU性能参数主要信息可以通过查看

/proc/cpuinfo

获得。具体查看指令及效果如下:

显示这台服务器上有2个物理CPU

显示这台服务器的物理核数纤基为16个

显示运行模式为64位

显示为Intel(R) Xeon(R) Gold 6226R CPU @ 2.90GHz

命令:

显示此服务器的线程数为64

top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。下面详细介绍它的使用方法。top是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前台,直到用户终止该程序为止.比较准确的说,top命令提供了实时的对系统处理器的状态监视.它将显示系统中CPU最“敏感”的任务列表.该命令可以按CPU使用.内存使用和执行时间对任务进行排序;而且该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定.

1.命令格式:

top

2.命令功能:

显示当前系统正在执行的进程的相关信息,包括进程ID、内存占用率、CPU占用率等

3.命令参数:

-b 批处理

-c 显示完整的治命令

-I 忽略失效过程

-s 保密模式

-S 累积模式

-i 设置间隔时间

-u 指定用户名

-p 指定进程

-n 循环显示的次数

4.使用实例:

实例1:通过 Top 命令显示进程信息

命令:

统计信息区:

前五行是当前系统情况整体的统计信息区。姿竖雀下面我们看每一行信息的具体意义。

之一行,任务队列信息,同 uptime 命令的执行结果,具体参数说明情况如下:

10:38:58 — 当前系统时间

up 39 days, 19:47 — 系统已经运行了39天19小时47分钟(在这期间系统没有重启过的吆!)

1 users — 当前有1个用户登录系统

load average: 0.00, 0.00, 0.00 — load average后面的三个数分别是1分钟、5分钟、15分钟的负载情况。

load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。

第二行,Tasks — 任务(进程),具体信息说明如下:

系统现在共有769个进程,其中处于运行中的有1个,463个在休眠(sleep),stoped状态的有0个,zombie状态(僵尸)的有0个。

第三行,cpu状态信息,具体属性说明如下:

0.0%us — 用户空间占用CPU的百分比。

0.0% sy — 内核空间占用CPU的百分比。

0.0% ni — 改变过优先级的进程占用CPU的百分迹早比

100.0% id — 空闲CPU百分比

0.0% wa — IO等待占用CPU的百分比

0.0% hi — 硬中断(Hardware IRQ)占用CPU的百分比

0.0% si — 软中断(Software Interrupts)占用CPU的百分比

备注:在这里CPU的使用比率和windows概念不同,需要理解linux系统用户空间和内核空间的相关知识!

第四行,内存状态,具体信息如下:

k total — 物理内存总量

k used — 使用中的内存总量

k free — 空闲内存总量

k buffers — 缓存的内存量

第五行,swap交换分区信息,具体信息说明如下:

k total — 交换区总量

k used — 使用的交换区总量

k free — 空闲交换区总量

备注:

第四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,空闲内存总量(free)是内核还未纳入其管控范围的数量。纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。

对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。

第六行,空行。

第七行以下:各进程(任务)的状态监控,项目列信息说明如下:

PID — 进程id

USER — 进程所有者

PR — 进程优先级

NI — nice值。负值表示高优先级,正值表示低优先级

VIRT — 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES

RES — 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA

SHR — 共享内存大小,单位kb

S — 进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程

%CPU — 上次更新到现在的CPU时间占用百分比

%MEM — 进程使用的物理内存百分比

TIME+ — 进程使用的CPU时间总计,单位1/100秒

COMMAND — 进程名称(命令名/命令行)

或者通过 free 命令显示系统内存的使用情况,包括物理内存、交换内存(swap)和内核缓冲区内存。

命令:

显示我当前的服务器的物理内存是62G,其中交换内存是2个G,一共剩余是60G的

三、查看Linux内核当前的系统版本号

命令:

linux系统中 webbench 测试性能过程中出现 Connect to server failed. Aborting benchmark. 怎么解决

这是没连上你的服务器的问题,看看你的域名解析做好没旁答,如果是

虚拟机

做枯前实验,在后边直接跟运败慧IP,别用域名。

关于linux性能测试工具 lmbench的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » Linux优化必备:深入了解lmbench性能测试工具 (linux性能测试工具 lmbench)