mapdb 开源包踩坑小记

在开发日志索引功能时,作者遇到了MapDB库的ArrayIndexOutOfBoundsException异常。经过一系列排查,发现问题源于使用了MapDB的Beta版本。切换到稳定版V1.0.9后,问题得到解决。此外,文章还对比了MapDB 1.0与2.0的性能,指出2.0有显著的性能提升。
摘要由CSDN通过智能技术生成

我开发的产品的模块中,近期增加了一个“日志索引”功能,用于快速在多个大文件中定位运行日志。

找到一个关键模块的开源软件 mapdb,这是一个好东西啊

  将map的快速与持久化(或半持久化)功能融合在一起,就是一个JAVA嵌入式的 Redis

   mapdb与Redis区别:   

      Redis也能完全相同的工作,但必竟其独立于JVM之外通过Socket交互,能达到10万次/秒就很不了不起了

      mapdb可直接嵌入到JVM运行空间,运行效率是Redis没法比的,单线程能达到 30万次/秒


   mapdb的使用场景:

       1、用于JVM内部的缓存,全内存操作,在标准Java map的基本上,增加过期时间、最大记录数等限制

       2、用于将Map中的内容持久化,可调用 db.commit()提交到文件

       3、用于大量map数据的持久化或半执久化(提升性能)

             本系统中用于日志索引的数据即为半持久化操作,每分钟提交一次即可,中间丢一部份数据也无所谓,设计上下次会进行“断点继续”


    本次从mapdb.org发布网站上下载了最新的版本,性能测试了一下,很优秀,API也比较人性化。


    遇到问题:

        集成到本系统中后,日志索引功能运行正常,对增量的日志建索引也比较快,每秒处理日志量 150M

        在系统做了其它多个功能模块修改后,最后集成的版本在日志索引这块运行有问题:

           每次启动时,mapdb模块报异常:

java.lang.ArrayIndexOutOfBoundsException: 2
        at org.mapdb.StoreDirect.recidToOffset(StoreDirect.java:1639)
        at org.mapdb.StoreWAL.get2(StoreWAL.java:450)
        at org.mapdb.Store.get(Store.java:253)
        at org.mapdb.HTreeMap.recursiveDirCount(HTreeMap.java:529)
        at org.mapdb.HTreeMap.sizeLong(HTreeMap.java:500)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

turandot

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值