「原创声明:保留所有权利,禁止转载」
FunTester 框架 Redis 性能测试之 map & INCR
在先前的文章中,我首先做了FunTester 框架 Redis 压测预备,然后分享了- FunTester 测试框架 Redis 性能测试实践,对普通的key-value类型的 Redis 操作进行了测试。再加上- FunTester 框架 Redis 性能测试之 list 操作一共产出了三篇文章,本来我的计划是通过多次不同的参数来对比 Redis 性能差异的,结果我发现其实没啥性能差异,都怪 Redis 性能太好了,我又不舍得拿本机测试极限性能。
所以本期文章接直接分享性能测试案例,分为 map 操作性和 INCR 操作。
map
思路
设计了一个简单的测试场景,用户先往某个值为 map 类型数据里面放一个 key-value 数据,然后查询这个 key 的 value 是否预期一致(其实有点多余),然后删除这个 key。
这个用例实在没想到具体的适用场景,就当我为了演示空想的用例。
用例
import com.funtester.base.constaint.FixedThread
import com.funtester.base.constaint.ThreadBase
import com.funtester.config.Constant
import com.funtester.db.redis.RedisBase
import com.funtester.frame.execute.Concurrent
import com.funtester.utils.StringUtil
import java.util.concurrent.atomic.AtomicInteger
/**
* FunTester测试框架,Redis压测,map
*/
class RedisList05 extends RedisBase {
static AtomicInteger num = new AtomicInteger(0)
static RedisBase drive
public static void main(String[] args) {
String host = "FunTester"
int port = 6379
drive = new RedisBase(host, port)
drive.index = 2
int times = 200
int thread = 10
Constant.RUNUP_TIME = 0
def tester = new FunTester(times)
def task = new Concurrent(tester, thread, "redis测试实践之map")
task.start()
drive.close()
}
private static class FunTester extends FixedThread {
String key = DEFAULT_STRING + num.getAndIncrement()
FunTester(int limit) {
super(null, limit, true)
}
@Override
protected void doing() throws Exception {
def k = "f" + getNanoMark()
def v = StringUtil.getString(10000)
drive.hset(key, k, v)
def hget = drive.hget(key, k)
if (v != hget) fail()
drive.hdel(key, k)
}
@Override
ThreadBase clone() {
return new FunTester(this.limit)
}
}
}
测试结果
此处省略一千八百字和二百七十张图。
INCR
Redis Incr 命令将 key 中储存的数字值增一。而 decr 方式是数字值减一。这个可以设计成为两个用例。
- 多线程对一个 key 进行递增操作,看是否线程安全
- 多线程对一个可以进行等量递增和递减,看是否线程安全
为了省事儿,我只演示第一种用例。
用例
import com.funtester.base.constaint.FixedThread
import com.funtester.base.constaint.ThreadBase
import com.funtester.config.Constant
import com.funtester.db.redis.RedisBase
import com.funtester.frame.execute.Concurrent
import java.util.concurrent.atomic.AtomicInteger
/**
* FunTester测试框架,Redis压测,incr
*/
class RedisList06 extends RedisBase {
static AtomicInteger num = new AtomicInteger(0)
static RedisBase drive
public static void main(String[] args) {
String host = "FunTester"
int port = 6379
drive = new RedisBase(host, port)
drive.index =2
int times = 200
int thread = 20
Constant.RUNUP_TIME = 0
def tester = new FunTester(times)
def task = new Concurrent(tester, thread, "redis测试实践之INCR")
task.start()
drive.close()
}
private static class FunTester extends FixedThread {
String listName = DEFAULT_STRING + num.getAndIncrement()
FunTester(int limit) {
super(null, limit, true)
}
@Override
protected void doing() throws Exception {
drive.incr("FunTester1123")
}
@Override
ThreadBase clone() {
return new FunTester(this.limit)
}
}
}
测试结果
此处省略一千八百字。
总结
FunTester 测试框架对 Redis 的性能测试系列已经完结,下一步会写 FunTester 测试框架对 MySQL 进行压测的实践系列,敬请期待……
Have Fun ~ Tester !
- FunTester 测试框架架构图初探
- 颇具年代感的《JMeter 中文操作手册》
- 140 道面试题目(UI、Linux、MySQL、API、安全)
- 未来的神器 fiddler Everywhere
- 测试之 JVM 命令脑图
- 好书推荐《Java 性能权威指南》
- 环境基础【FunTester 框架教程】
- 一起吐槽接口文档
- 绑定手机号性能测试
- Selenium4 Alpha-7 升级体验
- 连开 100 年会员会怎样
- LT 浏览器——响应式网站测试利器
- Java NIO 在接口自动化中应用
- 安卓 APP 测试知识大全【面试储备】
- JsonPath 验证类既 Groovy 重载操作符实践
TesterHome 为用户提供「保留所有权利,禁止转载」的选项。
除非获得原作者的单独授权,任何第三方不得转载标注了「原创声明:保留所有权利,禁止转载」的内容,否则均视为侵权。
具体请参见TesterHome 知识产权保护协议。
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
暂无回复。