性能工具之 nGrinder 入门安装及使用

简介: 【5月更文挑战第1天】性能工具之 nGrinder 入门安装及使用

一、介绍

nGrinder (http://naver.github.io/ngrinder/) 是基于 Grinder 开源项目,但由 NHN(据说是韩国最大的互联网公司)公司的 nGrinder 开发团队进行了重新设计和完善(所以叫做 nGrinde r)。nGrinder 是一款非常易用,有友好简洁的用户界面和 controller-agent 分布式结构的强大的压力测试工具。它是由一个 controller 和连接它的多个 agent 组成,用户可以通过 web 界面管理和控制测试,以及查看测试报告,controller 会把测试分发到一个或多个 agent 去执行。用户可以设置使用多个进程和线程来并发的执行该脚本,而且在同一线程中,来重复不断的执行测试脚本,来模拟很多并发用户

nGrinder 的测试是基于一个 Python/Groovy 的测试脚本,用户按照一定规则编写测试脚本以后,controller 会将脚本以及需要的其他文件分发到 agent,用 Jython 执行。并在执行过程中收集运行情况、响应时间、测试目标服务器的运行情况等。并保存这些数据生成运行报告,以供以后查看。

nGrinder 的一大特点就是非常容易使用,安装也非常容易,可以做到开箱即用,测试新手也可以很容易就开始测试任务。当然,如果想执行一些比较复杂场景的性能测试,就需要测试人员对 Python 有一定认识。

二、架构图

image.png

  • nGrinder 是基于 Grinder 的开源的 web 性能测试平台,由韩国最大互联网公司 NHN 公司的开发团队进行了重新设计和完善。
  • 特性:开源、易用、高可用、可扩展

  • 单节点支持 3000 并发、支持分布式、可监控被测服务器、可录制脚本、开源、平台化。

三、快速安装

1、下载二进制包

访问 Github:https://github.com/naver/ngrinder/releases
image.png

2、下载 tomcat 中间件

或者点击:https://tomcat.apache.org/download-90.cgi
image.png

3、安装应用

image.png

把下载好的【nGrinder-controller-3.4.3.war】包放到 Tomcat 的 webApps 文件夹中

image.png

注意:
永远不要将 war 文件放在包含像这样的文件夹的空间中 "C:\Program Files\Tomcat\webapps" 否則下载不了grinder-agent 端。

4、启动应用

image.png

5、浏览器访问

注意:
默认情况下,nGrinder 用 8080 作为 web 端访问的端口。

image.png

提供快速使用功能,工具比较成熟,开箱即用

6、安装 agent

image.png

下载后并且解压到相对目录:
image.png

运行成功如下:
image.png

平台验证是否有 agent 客户端:
image.png

image.png

四、简单使用

1、输入压测地址

咱们用 baidu 页面简单做一个测试:

image.png

输入要压测的请求地址:
image.png

该页面都是中文一看就知道怎么操作:
image.png

点击输入相关内容后保存并运行:
image.png
image.png

查看相关信息:
image.png

2、查看压测结果

image.png

查看详细结果:
image.png
image.png
image.png
image.png
image.png

3、查看压测脚本

image.png
下面就能看到文件夹,继续点击去就能看到脚本:

脚本如下:

/**

 * A simple example using the HTTP plugin that shows the retrieval of a
 * single page via HTTP.
 *
 * This script is automatically generated by ngrinder.
 *
 * @author admin
 */

@RunWith(GrinderRunner)

class TestRunner {
   
   

    public static GTest test
    public static HTTPRequest request
    public static NVPair[] headers = []
    public static NVPair[] params = []
    public static Cookie[] cookies = []

    @BeforeProcess

    public static void beforeProcess() {
   
   
        HTTPPluginControl.getConnectionDefaults().timeout = 6000
        test = new GTest(1, "www.baidu.com")
        request = new HTTPRequest()
        grinder.logger.info("before process.");
    }


    @BeforeThread 
    public void beforeThread() {
   
   
        test.record(this, "test")
        grinder.statistics.delayReports=true;
        grinder.logger.info("before thread.");
    }


    @Before
    public void before() {
   
   
        request.setHeaders(headers)
        cookies.each {
   
    CookieModule.addCookie(it, HTTPPluginControl.getThreadHTTPClientContext()) }
        grinder.logger.info("before thread. init headers and cookies");
    }


    @Test
    public void test(){
   
   
        HTTPResponse result = request.GET("https://www.baidu.com/", params)
        if (result.statusCode == 301 || result.statusCode == 302) {
   
   
            grinder.logger.warn("Warning. The response may not be correct. The response code was {}.", result.statusCode); 
        } else {
   
   
            assertThat(result.statusCode, is(200));
        }
    }
}

五、小结

以上为 nGrinder 入门安装及简单使用介绍,下一篇分享参数化与分布式压测。

相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
目录
相关文章
|
15小时前
|
数据挖掘 测试技术 BI
性能工具之 Gatling 快速入门
Gatling 是一款基于 Scala 开发的高性能服务器性能测试工具,它主要用于对服务器进行负载等测试,并分析和测量服务器的各种性能指标。
40 1
性能工具之 Gatling 快速入门
|
15小时前
|
Java 应用服务中间件 开发工具
性能工具之 nGrinder 源码安装
【5月更文挑战第2天】性能工具之 nGrinder 源码安装
27 2
性能工具之 nGrinder 源码安装
|
15小时前
|
JSON Java Linux
性能工具之 JMeter 快速入门
【5月更文挑战第10天】性能工具之 JMeter 快速入门
16 5
性能工具之 JMeter 快速入门
|
15小时前
|
测试技术 Docker 容器
性能工具之Taurus快速入门
【5月更文挑战第8天】性能工具之Taurus快速入门
15 1
性能工具之Taurus快速入门
|
15小时前
|
XML 存储 测试技术
性能工具之Taurus进阶场景使用
【5月更文挑战第9天】性能工具之Taurus进阶场景使用
19 3
性能工具之Taurus进阶场景使用
|
15小时前
|
SQL JSON Java
性能工具之 nGrinder Get 请求脚本编写
【5月更文挑战第3天】性能工具之 nGrinder Get 请求脚本编写
28 8
|
15小时前
|
Ubuntu 物联网 Linux
性能工具之emqtt_bench快速上手
【4月更文挑战第8天】MQTT 协议是目前最适合物联网场景数据平台搭建的通信协议。基于此,BenchMark 联网场景中的 MQTT 消息采集与传递,以及如何构建一个百万级,甚至千万级 MQTT 消息平台,可以为物联网业务的企业用户提供平台架构设计参考。
37 2
性能工具之emqtt_bench快速上手
|
15小时前
|
监控 测试技术 Python
性能工具之 Locust 简单入门
【4月更文挑战第1天】Locust是一个易于使用,分布式,用户负载测试工具。它用于负载测试web站点(或其他系统)并计算一个系统可以处理多少并发用户。
31 1
性能工具之 Locust 简单入门
|
15小时前
|
Java Scala Maven
性能工具之 Gatling 开发环境搭建
编写 Gatling 脚本需要搭建脚本开发环境,下面演示使用 IDEA 开发环境搭建脚本开发环境。
30 2
性能工具之 Gatling 开发环境搭建
|
16小时前
|
开发框架 算法 .NET
新手友好、轻量级的C#/.NET万能工具库
新手友好、轻量级的C#/.NET万能工具库