文档章节

用Ngrinder轻松进行性能测试

anglix
 anglix
发布于 2015/11/28 21:03
字数 485
阅读 1401
收藏 11

Ngrinder入门

安装

基础环境

  • 以 Ngrinder-3.2.3 为例,建议用 JDK-1.6:

    mkdir -pv /data/{app,log}
    wget -P /data/log dl.higkoo.com/{jdk1.6.0_45.tgz,ngrinder-controller-3.2.3-with-tomcat.tar.gz,ngrinder-core-3.2.3-agent-package.tar.gz}
    tar -C /data/app -zxvf /data/log/jdk1.6.0_45.tgz
    tar -C /data/app -zxvf /data/log/ngrinder-controller-3.2.3-with-tomcat.tar.gz
    tar -C /data/app -zxvf /data/log/ngrinder-core-3.2.3-agent-package.tar.gz
    ln -s /data/app/jdk1.6.0_45/bin/java /usr/sbin/java

控制台管理

  • 控制端是 tomcat 启动的服务(默认端口 8080 / 默认帐号 admin/admin):

    export JAVA_HOME=/data/app/jdk1.6.0_45
    /data/app/apache-tomcat-6.0.35/bin/startup.sh

负载生成器

  • 启动的第1个参数填控制台的IP地址或域名

    export JAVA_HOME=/data/app/jdk1.6.0_45
    /data/app/ngrinder-core-3.2.3/run_agent_bg.sh 192.168.10.31

编写测试脚本

  • 如下脚本为常用 GET、POST 带参数和自定义HTTP头的方法:

示例脚本

private static final String URL = "http://api.higkoo.com:9080/status";// 请求使用的URL
private static final NVPair[] PARAMS = [
	new NVPair("color", "Magic"),
	new NVPair("expect", "Miracle"),
] as NVPair[]; // 请求的参数列表
private static final NVPair[] HEADERS = [ 
	new NVPair("Cookie", "date=20151128;path=/"),
	new NVPair("User-Agent", "nGrinder"),
] as NVPair[];// 自定义头信息
@Test
public void test(){
	HTTPResponse result = request.GET(URL, PARAMS, HEADERS) // request.POST(URL, PARAMS, HEADERS)
	if (result.statusCode == 301 || result.statusCode == 302) {
		grinder.logger.warn("Warning. The response code was {}.", result.statusCode); 
	} else {
		assertThat(result.statusCode, is(200));
	}
}

执行压测

  • 测试过程要对和个服务器的资源使用情况有所了解,下图展示过程中 控制端、被测试的服务端,以及可爱的肉鸡的 top图:

资源使用图

  • 不断增加虚拟用户数(15台24核32G的服务器),结果如下:

测试结果

  1. 本次测试以nginx状态页为例
  2. 虚拟用户乘10倍增加,响应时间几乎也同级增加
  3. 然而虚拟用户数增加,每秒响应请求数并没有质的增加
  4. 当虚拟用户数过6万时,服务器出现拒绝访问

[Sat Nov 28 19:04:46 2015] TCP: TCP: Possible SYN flooding on port 80. Sending cookies. Check SNMP counters.

附加信息

  • 然而 LoadRunner 并不支持 Debian 系统:

LoadRunner安装

© 著作权归作者所有

共有 人打赏支持
anglix

anglix

粉丝 31
博文 35
码字总数 17615
作品 0
珠海
系统管理员
私信 提问
使用nGrinder实现性能测试驱动开发

来自 : Performance Driven Development 作者 : Juno.Yoon 使用nGrinder实现性能测试驱动开发 在许多项目中,开发者们通常不会在项目中期就考虑到各种非功能性要点。他们经常只是专注于功能...

nGrinderChina
2013/03/06
0
0
nGrinder在大型组织中的实际布署和应用

原文 : nGrinder Real Deployment in the Large Organization By JunHo.Yoon 我们的公司,NHN,拥有多个大型的产品。其中一个是韩国最受欢迎的搜索门户网站NAVER,拥有超过5千万的用户。另一个...

nGrinderChina
2013/03/12
0
0
开源nGrinder-3分钟学会世界上最简单但潜力无限的压力工具

nGrinder运行一个压力测试只需3步启动1个test: 1)Python脚本编写测试场景;2)配置虚拟用户数,周期,步长控制,资源监控;3)运行结束报告自动生成,TPS/MeanTime/Errors, 监控CPU/Memor...

nGrinderChina
2013/02/20
0
0
nGrinder 3.3 发布,Web 压力测试工具

nGrinder 3.3 发布,这是主要版本发布,主要包括功能增强,新特性和 bug 修复。nGrinder agent 和 controller 都可以升级到 3.3 版本。 主要更新内容如下: 单一可执行包 修复了 controller...

oschina
2014/02/12
4.7K
1
nGrinder-世界上最简单但潜力无限的压力工具

此次此刻,我很高兴能把nGrinder-也许是这世界上最简单但潜力无限的压力工具介绍给大家。我是Emily, 来自NDT(nGrinder开发团队)的发言人。 下面这些问题正在烦扰着你么? -想要优化你的网...

nGrinderChina
2013/01/31
0
0

没有更多内容

加载失败,请刷新页面

加载更多

一、什么是ActiveMQ

首先我们应该先了解J2EE中的一个重要规范:JMS(The Java Message Service)Java消息服务。而JMS的客户端之间可以通过JMS服务进行异步的消息传输。它主要有两种模型:点对点和发布订阅模型。 ...

watermelon11
17分钟前
0
0
课时17 第三课Spark内部原理剖析与源码阅读(五)

为何spark shuffle比mapreduce shuffle慢? 主要是spark shuffle的shuffle read阶段还不够优秀,它是基于hashmap实现的,shuffle read会把shuffel write阶段已经排序数据给重新转成乱序的,转...

刀锋
33分钟前
1
0
Function函数式接口

Function函数式接口传入一个参数,返回一个值。 然后我们使用这个写个demo看看: 输出: 接口内部还有两个default方法和一个static方法,然后我们先看一下static方法 返回一个始终返回其输入...

woshixin
48分钟前
1
0
开发者和架构师之间最大的区别是什么?

1、开发者和架构师之间最大的区别是什么? 架构师和开发者一样,也经常写代码,简单的说,开发者和架构师之间最大的区别就是技术领导力。 软件架构师的角色需要理解最重要的架构驱动力是什么...

James-
今天
2
0
java框架学习日志-4

补充一些spring配置文件的方法。 设置别名: <!--通过name直接设置别名--> <bean name="user2" class="cn.sxt.factory.UserDynamicFactory"> </bean> <!--有id的情况下也可以设置......

白话
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部