Jmeter中间件处理-缓存
前言
消息队列和缓存是目前主流的中间件,我们在日常测试过程中,无论是接口还是压力测试,都会遇到需要处理这些中间件数据的情况。本文以Redis对缓存做一个简单的介绍,并基于Jmeter实现缓存数据处理。
缓存
Web系统通常使用数据库来存储数据,但数据库存取涉及到磁盘读写,磁盘IO读写速度明显慢于内存读写速度,当并发量很大的时候,很容易成为系统瓶颈。为了提高数据的存取速度,避免系统瓶颈,越来越多的Web系统引入了缓存数据库。目前主流的缓存数据库有Redis和MongoDB,Jmeter通过扩展插件支持这两种内存数据库的数据库读取。本文以Redis为例,介绍如何使用Jmeter读取和使用Redis数据。
Redis服务和客户端安装
1. 官网下载Redis 安装文件
https://github.com/microsoftarchive/redis/releases
2. 在Windows平台上双击redis-server.exe文件即可启动Redis服务,控制台出现如下所述提示,说明Redis-Server启用成功
3. 下载安装Windows客户端,双击运行出现如下界面;通过客户端在Redis数据库中添加数据,本示例添加了一个List类型的数据,key=testList,值有a,b,c 三种
Redis是内存数据库,和Mysql这类关系型数据的表结构不同,Redis有如下6种数据结构:
String:Key-Value管理键值对.
Set:String 类型的无序集合,集合成员是唯一的,集合中不能出现重复的数据。
List:字符串列表,按照插入顺序排序。
Hash:Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。
Sorted Set:有序集合和集合一样也是string类型元素的集合, 不同的是每个元素都会关联一个double类型的分数,redis正是通过分数来为集合中的成员进行从小到大的排序。
Jmeter使用Redis
打开JMeter Plugins Manager,下载Jmeter Redis Data Set插件
重启Jmeter以后,可以在配置元件中发现新增组件 jp@gc-Redis Data Set,Jmeter的Redis Data Set目前尚有一些限制,仅支持List和Set类型的数据;如果要处理其他类型的数据,可以通过Beanshell Sampler来编写代码读取Redis数据
Redis Data Set可以实现读取Redis中的数据,并将数据存储为变量供后续使用,其中关键的配置有:
Redis Key:对应Redis数据库中的Key
Variable Name:Redis数据库中取出数据后存储的变量,可以供Jmeter后续的脚本使用
Delimiter:分隔符,默认是
Data Source Type: Redis数据类型,此处仅支持List和Set
Recycle data on use: 当数据遍历完时是否重新开始循环
Connection Configuration:Redis 服务器的配置信息,包括Redis服务器的IP,端口,超时时间,密码和数据库名
Redis Pool Configuration:Redis的连接池配置
本示例读取了本地Redis数据库的testList数据,并且取出数据作为百度搜索的关键词
点击运行,脚本能从Redis数据库中取出数据,并作为后续Http请求的输入参数
Jmeter功能非常强大,尤其是对多种中间件的支持,小伙伴们赶紧用起来吧,预知Jmeter如何处理消息队列,请听下回分解。
作 者:Testfan Kitty
出 处:微信公众号:自动化软件测试平台
版权说明:欢迎转载,但必须注明出处,并在文章页面明显位置给出文章链接