服务器测试工具,服务器压力测试软件

如何在Windows服务器做性能测试

一、远程连接到Windows服务器,使用windows系统自带工具进行收集性能数据

1、Windows服务器中自带的性能监控工具叫做Performance Monitor,在开始-运行中输入‘Perfmon.msc’,然后回车即可运行。通过界面,控制面板\所有控制面板项\管理工具\性能监视器也能打开

打开后,页面展示

2、添加计数器

性能>数据收集器集>用户定义[右击]>新增‘数据收集器集’>手动创建高级>下一步

勾选创建数据日志>性能计数器>【下一步】

点击“添加”→选择计数器

点击选中的可用计数器>【添加】>【确定】

【确定】>【下一步】

选择目录后,点击【完成】

查看新增的计数器,输出地方为日志输出地址

3、选择日志数据源格式

选择用户定义下的数据收集器集>右键属性>性能计数器,日志格式选择“逗号分隔”(即csv格式)

4、开始启动数据采集,选择用户定义下的数据收集器集>右键属性>开始

此时,输出有地址了

5、用EXCEL将数据转换为折线图,并分析性能情况

二、分析性能情况

(1)内存泄露判断

●虚拟内存字节数(VirtualBytes)应该远大于工作集字节数(Workingset),如果两者变化规律相反,比如说工作集增长较快,虚拟内存增长较少,则可能说明出现了内存泄露的情况。

●对于Workingset、Private Bytes、Availablebytes这些计数器,如果在测试期间内数值持续增长,而且测试停止后位置在高水平,则也说明存在内存泄露。

●Windows资源监控中,如果Process\PrivateBytes计数器和Process\WorkingSet计数器的值在长时间内持续升高,同时Memory\Available

bytes计数器的值持续降低,则很可能存在内存泄漏。

(2)CPU使用情况

●一般平均不要超过70%,最大不要超过90%(好:70%、坏:85%、很差:90%)

(3)tps(每秒处理事务的数量,在SOAPUI中进行统计)

●一般在10-100,不同应用程序具体值不同

1234567891011121314151617

几个常用参数的参考值:CPU:% ProcessorTime:表示CPU的使用率,如果值大于80表示CPU的处理调度能力偏低。硬盘:% DiskTime:表示硬盘的I/O操作的频率(繁忙时间),如果值大于80表示硬盘I/O调度能力偏低。Average Disk QueueLength:表示硬盘I/O操作等待队列的长度,如果值大于2表示硬盘I/O调度能力偏低。内存Pages/Sec:表示系统对虚拟内存每秒钟的访问次数,如果值大于20表示有内存方面的问题。(有可能是物理内存偏低,也有可能是虚拟内存没有配置正确。一般情况下虚拟内存应为物理内存的1.5-2倍)CommittedBytesandAvailable Bytes:CommittedBytes表示虚拟内存的大小,Available Bytes表示剩余可用内存的大小。正常情况下,Available Bytes减少,pages(页面数)应该增加,提供页面交换。<br>如果Available Bytes的值很小表示物理内存偏低。当关闭一些应用以后,CommittedBytes应该减少,Available Bytes应该增加。因为关闭的进程释放了之前占用的内存资源。如果相应的值没有发生变化,那么该进程就可能造成了内存泄漏。Cache Bytes:表示系统缓存的大小。如果值大于4M表示物理内存偏低。

三、关于计数器的选择

perfmon的计数器主要分四种:处理器性能计数器、内存性能计数器、磁盘性能计数器以及网络性能计数器。

以下为监控服务器常用的计数器:

常用的性能对象与指标

性能对象

计数器

提供的信息

Processor

% Idle Time

% Idle Time是处理器在采样期间空闲的时间的百分比

Processor

% Processor Time

% Processor Time指处理器用来执行非闲置线程时间的百分比。计算方法是,测量范例间隔内非闲置线程活动的时间,用范例间隔减去该值。这个计数器是处理器活动的主要说明器,显示在范例间隔时所观察的繁忙时间平均百分比。

Processor

% User Time

% User Time指处理器处于用户模式的时间百分比。用户模式是为应用程序、环境分系统和整数分系统设计的有限处理模式。

Memory

Available Bytes

Available Bytes显示出当前空闲的物理内存总量。当这个数值变小时,Windows开始频繁地调用磁盘页面文件。如果这个数值很小,例如小于5 MB,系统会将大部分时间消耗在操作页面文件上。

Memory

% Committed Bytes in Use

% Committed Bytes In Use是 Memory: Committed Bytes与Memory: Commit Limit之间的比值。(Committed memory指如果需要写入磁盘时已在分页文件中保留空间的处于使用中的物理内存。Commit Limit是由分页文件的大小而决定的。如果扩大了分页文件,该比例就会减小)。这个计数器只显示当前百分比;而不是一个平均值。

Memory

Page Faults/sec

Page Faults/sec是指处理器处理错误页的综合速率。用错误页数/秒来计算。当处理器请求一个不在其工作集(在物理内存中的空间)内的代码或数据时出现的页错误。这个计数器包括硬错误(那些需要磁盘访问的)和软错误(在物理内存的其它地方找到的错误页)。许多处理器可以在有大量软错误的情况下继续操作。但是,硬错误可以导致明显的拖延。这个计数器显示用上两个实例中观察到的值之间的差除以实例间隔的持续时间所得的值。

Network Interface

Bytes Total/sec

Bytes Total/sec是发送和接收字节的速率,包括帧字符在内。

Network Interface

Packets/sec

Packets/sec为发送和接收数据包的速率。

Physical Disk

% Busy Time

% Busy Time指磁盘驱动器忙于为读或写入请求提供服务所用的时间的百分比。

Physical Disk

Avg. Disk Queue Length

Avg. Disk Queue Length指读取和写入请求(为所选磁盘在实例间隔中列队的)的平均数。

Physical Disk

Current Disk Queue Length

Current Disk Queue Length指在收集操作数据时在磁盘上未完成的请求的数目。它包括在快照内存时正在为其提供服务中的请求。这是一个即时长度而非一定间隔时间的平均值。多主轴磁盘设备可以一次有多个请求操作,但是其它同时发生的请求为等候服务。这个计数器可能会反映一个暂时的高或低的列队长度,但是如果在磁盘驱动器存在持续负载,可能值会总是很高。请求等待时间与这个列队的长度减去磁盘上的主轴成正比。这个差值应小于2才能保持良好的性能。

Logical

Disk

% Free Space

% Free Space是所选定的逻辑磁盘驱动器上总的可用空闲空间的百分比。

Logical

Disk

Free Megabytes

可用的 MB显示磁盘驱动器上尚未分配的空间。

以下为监控进程常用的计数器:

Process对象的主要指标

性能对象

计数器

提供的信息

Process

% Privileged Time

% Privileged Time是在特权模式下处理线程执行代码所花时间的百分比。当调用 Windows系统服务时,此服务经常在特权模式运行,以便获取对系统专有数据的访问。在用户模式执行的线程无法访问这些数据。对系统的调用可以是直接的(explicit)或间接的(implicit),例如页面错误或间隔。

Process

% Processor Time

% Processor Time是所有进程线程使用处理器执行指令所花的时间百分比。指令是计算机执行的基础单位。线程是执行指令的对象,进程是程序运行时创建的对象。此计数包括处理某些硬件间隔和陷阱条件所执行的代码。

Process

% User Time

% User Time指处理线程用于执行使用用户模式的代码的时间的百分比。应用程序、环境分系统和集合分系统是以用户模式执行的。Windows的可执行程序、内核和设备驱动程序不会被以用户模式执行的代码损坏。

Process

Creating Process ID value

Creating Process ID value指创建该进程的父进程号。

Process

Elapsed Time

该进程运行的总时间(用秒计算)。

Process

Handle Count

由这个处理现在打开的句柄总数。这个数字等于这个处理中每个线程当前打开的句柄的总数。

Process

ID Process

ID Process指这个处理的特别的识别符。ID Process号可重复使用,所以这些 ID Process号只能在一个处理的寿命期内识别那个处理。

Process

IO Data Bytes/sec

处理从 I/O操作读取/写入字节的速度。这个计数器为所有由本处理产生的包括文件、网络和设备 I/O的活动计数。

Process

IO Data Operations/sec

本处理进行读取/写入 I/O操作的速率。这个计数器为所有由本处理产生的包括文件、网络和设备 I/O的活动计数。

Process

IO Other Bytes/sec

处理给不包括数据的 I/O操作(如控制操作)字节的速率。这个计数器为所有由本处理产生的包括文件、网络和设备 I/O的活动计数。

Process

IO Other Operations/sec

本处理进行非读取/写入 I/O操作的速率。例如,控制性能。这个计数器为所有由本处理产生的包括文件、网络和设备 I/O的活动计数。

Process

IO Read Bytes/sec

处理从 I/O操作读取字节的速度。这个计数器为所有由本处理产生的包括文件、网络和设备 I/O的活动计数。

Process

IO Read Operations/sec

本处理进行读取 I/O操作的速率。这个计数器为所有由本处理产生的包括文件、网络和设备 I/O的活动计数。

Process

IO Write Bytes/sec

处理从 I/O操作写入字节的速度。这个计数器为所有由本处理产生的包括文件、网络和设备。

Process

IO Write Operations/sec

本处理进行写入 I/O操作的速率。这个计数器为所有由本处理产生的包括文件、网络和设备 I/O的活动计数。

Process

Page Faults/sec

Page Faults/sec指在这个进程中执行线程造成的页面错误出现的速度。当线程引用了不在主内存工作集中的虚拟内存页即会出现 Page Fault。如果它在备用表中(即已经在主内存中)或另一个共享页的处理正在使用它,就会引起无法从磁盘中获取页。

Process

Page File Bytes

Page File Bytes指这个处理在 Paging file中使用的最大字节数。Paging File用于存储不包含在其他文件中的由处理使用的内存页。Paging File由所有处理共享,并且 Paging File空间不足会防止其他处理分配内存。

Process

Page File Bytes Peak

Page File Bytes Peak指这个处理在 Paging files中使用的最大数量的字节。

Process

Pool Nonpaged Bytes

Pool Nonpaged Bytes指在非分页池中的字节数,非分页池是指系统内存(操作系统使用的物理内存)中可供对象(指那些在不处于使用时不可以写入磁盘上而且只要分派过就必须保留在物理内存中的对象)使用的一个区域。这个计数器仅显示上一次观察的值;而不是一个平均值。

Process

Pool Paged Bytes

Pool Paged Bytes指在分页池中的字节数,分页池是系统内存(操作系统使用的物理内存)中可供对象(在不处于使用时可以写入磁盘的)使用的一个区域。这个计数器仅显示上一次观察的值;而不是一个平均值。

Process

Priority Base

这次处理的当前基本优先权。在一个处理中的线程可以根据处理的基本优先权提高或降低自己的基本优先权。

Process

Private Bytes

Private Bytes指这个处理不能与其他处理共享的、已分配的当前字节数。

Process

Thread Count

在这次处理中正在活动的线程数目。指令是在一台处理器中基本的执行单位,线程是指执行指令的对象。每个运行处理至少有一个线程。

Process

Virtual Bytes

Virtual Bytes指处理使用的虚拟地址空间的以字节数显示的当前大小。使用虚拟地址空间不一定是指对磁盘或主内存页的相应的使用。虚拟空间是有限的,可能会限制处理加载数据库的能力。

Process

Virtual Bytes Peak

Virtual Bytes Peak指在任何时间内该处理使用的虚拟地址空间字节的最大数。

Process

Working Set

Working Set指这个处理的 Working Set中的当前字节数。Working Set是在处理中被线程最近触到的那个内存页集。如果计算机上的可用内存处于阈值以上,即使页不在使用中,也会留在一个处理的 Working Set中。当可用内存降到阈值以下,将从 Working Set中删除页。如果需要页时,它会在离开主内存前软故障返回到 Working Set中。

Process

Working Set Peak

Working Set Peak指在任何时间这个在处理的 Working Set的最大字节数。

自动化测试的工具有哪些

QTP

全名HP QuickTest Professional software,2012年12月6日发布11.5版本,并更名为Unified Functional TestingQTP是quicktest Professional的简称,是一种自动测试工具。使用QTP的目的是想用它来执行重复的手动测试,主要是用于回归测试和测试同一软件的新版本。因此你在测试前要考虑好如何对应用程序进行测试,例如要测试那些功能、操作步骤、输入数据和期望的输出数据等

QuickTest针对的是GUI应用程序,包括传统的Windows应用程序,以越来越流行的Web应用。它可以覆盖绝大多数的软件开发技术,简单高效,并具备测试用例可重用的特点。其中包括:创建测试、插入检查点、检验数据、增强测试、运行测试、分析结果和维护测试等方面。

WinRunner

Mercury Interactive公司的WinRunner是一种企业级的功能测试工具,用于检测应用程序是否能够达到预期的功能及正常运行。通过自动录制、检测和回放用户的应用操作,WinRunner能够有效地帮助测试人员对复杂的企业级应用的不同发布版进行测试,提高测试人员的工作效率和质量,确保跨平台的、复杂的企业级应用无故障发布及长期稳定运行。企业级应用可能包括Web应用系统,ERP系统,CRM系统等等。这些系统在发布之前,升级之后都要经过测试,确保所有功能都能正常运行,没有任何错误。如何有效地测试不断升级更新且不同环境的应用系统,是每个公司都会面临的问题。

RationalRobot

是业界最顶尖的功能测试工具,它甚至可以在测试人员学习高级脚本技术之前帮助其进行成功的测试。它集成在测试人员的桌面IBM Rational Test Manager上,在这里测试人员可以计划、组织、执行、管理和报告所有测试活动,包括手动测试报告。这种测试和管理的双重功能是自动化测试的理想开始。

AdventNetQEngine

AdventNet QEngine是一个应用广泛且独立于平台的自动化软件测试工具,可用于Web功能测试、web性能测试、Java应用功能测试、Java API测试、SOAP测试、回归测试和Java应用性能测试。支持对于使用HTML、JSP、ASP、.NET、PHP、JavaScript/VBScript、XML、SOAP、WSDL、e-commerce、传统客户端/服务器等开发的应用程序进行测试。此工具以Java开发,因此便于移植和提供多平台支持。

SilkTest

是业界领先的、用于对企业级应用进行功能测试的产品,可用于测试Web、Java或是传统的C/S结构。SilkTest提供了许多功能,使用户能够高效率地进行软件自动化测试。这些功能包括:测试的计划和管理;直接的数据库访问及校验;灵活、强大的4Test脚本语言,内置的恢复系统(Recovery System);以及具有使用同一套脚本进行跨平台、跨浏览器和技术进行测试的能力。

QARun

QARun的测试实现方式是通过鼠标移动、键盘点击操作被测应用,即而得到相应的测试脚本,对该脚本可以进行编辑和调试。在记录的过程中可针对被测应用中所包含的功能点进行基线值的建立,换句话说就是在插入检查点的同时建立期望值。在这里检查点是目标系统的一个特殊方面在一特定点的期望状态。通常,检查点在QARun提示目标系统执行一系列事件之后被执行。检查点用于确定实际结果与期望结果是否相同

TestPartner

是一个自动化的功能测试工具,它专为测试基于微软、Java和Web技术的复杂应用而设计。它使测试人员和开发人员都可以使用可视的脚本编制和自动向导来生成可重复的测试,用户可以调用VBA的所有功能,并进行任何水平层次和细节的测试。TestPartner的脚本开发采用通用的、分层的方式来进行。没有编程知识的测试人员也可以通过TestPartner的可视化导航器来快速创建测试并执行。通过可视的导航器录制并回放测试,每一个测试都将被展示为树状结构,以清楚地显现测试通过应用的路径。

Holodeck-强大的故障植入软件测试工具

TelelogicTAU

TAU第二代包含三个最新的、最强大的技术用来加速大规模软件开发和测试:统一建模语言(UML)及它的许多最新修订版本中的特性,UML2.0;功能强大的测试语言TTCN-3和新的构造系统的方法:Model Driven Architecture(模型驱动构架)。这三个新的业界标准结合成TAU的已经过认可的软件开发平台,形成了一个系统,一个一流的稳定可靠的工具解决方案。TAU第二代是系统与软件开发解决方案的一个突破,它把业界从使用了太长时间的手工、易出错、以代码为中心的方法中释放出来,自然而然地迈向下一步,一个更加可视化、自动化及可靠的开发方法。Telelogic TAU/Tester是基于通用测试语言TTCN-3,用于自动化的系统和集成测试的强大工具。TAU/Tester以现代化的开发工具为基础,提供高层测试功能,支持整个测试生命周期,加速自动化测试。TAU/Tester可使用户特别关注于测试的开发,因为TTCN-3语言是独立于开发语言或测试设备的,且是抽象和可移植的。

试工具。最新版本是1.1.8,该工具支持无脚本执行模式,无人值守执行模式,自由定制模式。不仅执行模式可以定制,功能模块也支持定制。使用该工具的界面创建用例,组装脚本,启动执行。使用该工具其他开放的接口,可手动创建脚本,组装并执行。它支持两种部署模式,第一种是Server-Client方式,Server与Client均为EXE程序,通信协议是Socket;另一种是WEB版部署,方便与现有系统集成,支持Linux,将Server与Client放到Tomcat或Weblogic服务器下部署,通信协议为Http,通过WEB页面控制并监控Client端的执行。

服务器压力测试需要用的8种工具

服务器压力测试是确保网站性能和稳定性的重要手段。在进行压力测试时,选择合适的工具至关重要。本文将介绍8款常用的服务器性能压力测试工具,帮助你了解如何通过这些工具来评估Web服务器的负载能力和性能指标。

首先,我们来了解一下Web Application Stress Tool(WAST)。这是一款专门用于网站压力测试的工具,由微软的网站测试人员开发,能够有效测试Web服务器的运行状态和响应时间。通过WAST,你可以轻松地模拟大量并发连接,测试网站在高负载下的性能。

接着,我们介绍webbench。这是一个轻量级的Linux下的网站压力测试工具,最多支持3万个并发连接,非常适合用于测试网站的负载能力。安装过程简单,只需要解压并运行即可开始使用。

Apache Bench(ab)是一款功能强大的测试工具,主要用于测试Apache服务器的性能。安装了Apache服务器后,ab通常会自动包含在系统中。通过简单的命令,如指定并发连接数和测试时间,你可以快速进行压力测试。

Siege是一款开源的压力测试工具,能够模拟多用户的并发访问,记录请求响应时间,并在预设的并发访问下重复测试。使用Siege时,只需要指定并发量、重复次数以及访问的URL列表。

LoadRunner是一款老牌的压力测试工具,被广泛应用于预测系统行为和性能。它提供了一套完整的解决方案,包括录制性能测试脚本、分析测试结果等。LoadRunner适用于各种体系架构,支持广泛的协议和技术。

JMeter是一款广受欢迎的开源分布式压力测试产品,能够生成图形报告。除了用于Web应用测试外,JMeter还可以测试静态和动态资源,如静态文件、Java小服务程序、CGI脚本等。它提供了强大的功能,包括断言验证、脚本录制等。

Tsung是一款开源的多协议分布式负载测试工具,支持HTTP、WebDAV、SOAP、PostgreSQL、MySQL、LDAP、MQTT等多种协议的压力测试。Tsung特别适用于进行大规模分布式测试。

locust.io是一个开源的负载测试工具,使用Python代码定义用户行为。它支持分布式测试,并提供了Web UI界面,便于进行压力测试。通过Python脚本定义压测规则,locust.io能够实现高效的性能测试。

阿里云PTS是一个SaaS性能测试平台,具备强大的分布式压测能力,能够模拟海量用户的真实业务场景。PTS平台支持压测机服务,无需额外安装软件,提供了脚本场景监控、分布式并发压测等功能,适用于验证业务站点的性能、容量和稳定性。

大部分服务器压力测试工具都是免费的,而阿里云PTS则提供收费服务。选择工具时,应根据实际需求和预算来决定。本文列举的8款工具覆盖了不同的使用场景,希望能帮助你根据项目需求进行选择。通过进行压力测试,你可以合理设定网站上线后的预期访问量,并确保系统能够应对峰值流量,从而确保项目的顺利上线。

阅读剩余
THE END