前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >FunTester框架Redis性能测试之map & INCR

FunTester框架Redis性能测试之map & INCR

作者头像
FunTester
发布2021-10-08 11:20:00
6030
发布2021-10-08 11:20:00
举报
文章被收录于专栏:FunTester

在先前的文章中,我首先做了FunTester框架Redis压测预备,然后分享了- FunTester测试框架Redis性能测试实践,对普通的「key-value」类型的Redis操作进行了测试。再加上- FunTester框架Redis性能测试之list操作一共产出了三篇文章,本来我的计划是通过多次不同的参数来对比Redis性能差异的,结果我发现其实没啥性能差异,都怪Redis性能太好了,我又不舍得拿本机测试极限性能。

所以本期文章接直接分享性能测试案例,分为map操作性和INCR操作。

map

思路

设计了一个简单的测试场景,用户先往某个值为map类型数据里面放一个key-value数据,然后查询这个key的value是否预期一致(其实有点多余),然后删除这个key。

这个用例实在没想到具体的适用场景,就当我为了演示空想的用例。

用例

代码语言:javascript
复制
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进行递增操作,看是否线程安全
  • 多线程对一个可以进行等量递增和递减,看是否线程安全

为了省事儿,我只演示第一种用例。

用例

代码语言:javascript
复制

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)
        }
    }

}


测试结果

此处省略一千八百字。

incr结果验证

总结

FunTester测试框架对Redis的性能测试系列已经完结,下一步会写FunTester测试框架对MySQL进行压测的实践系列,敬请期待……

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-09-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 FunTester 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • map
    • 思路
      • 用例
        • 测试结果
        • INCR
          • 用例
            • 测试结果
            • 总结
            相关产品与服务
            云数据库 Redis
            腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档