关于布隆过滤器原理这里不做过多解释,如不明白可以先查询资料搞清楚原理与使用场景再来看本篇文章,开头我要先指出几个问题
1.redisson利用redis存储,布隆过滤器生成数组,但是长度限制为 4 294 967 296 ,但是根据布隆过滤器的原理来看,生成的数组长度是没有限制的,我判断是redis String类型最大是512M所导致的限制,这是问题一长度有限制。
2. 在初始化布隆过滤器时,指定的容量超过一亿时,误判率急剧增高,几乎到了不能用的地步,这跟guava的布隆过滤器在容量超过一亿时误判率增高趋势一样
下面直接看代码把
先编写配置类
import org.redisson.Redisson; import org.redisson.api.RedissonClient; import org.redisson.config.Config; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.autoconfigure.data.redis.RedisProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class RedissonConfig { @Autowired RedisProperties redisProperties; @Bean public RedissonClient redissonClient() { Config config = new Config(); String redisUrl = String.format("redis://%s:%s", redisProperties.getHost() + "", redisProperties.getPort() + ""); config.useSingleServer().setAddress(redisUrl).setPassword(redisProperties.getPassword()); return Redisson.create(config); } }
redis工具类
import org.redisson.api.RBloomFilter; import org.redisson.api.RedissonClient; @Component public class RedisUtil { @Autowired RedissonClient redissonClient; public void bloomFilterInit(String bloomFilterName) { RBloomFilterbloomFilter = redissonClient.getBloomFilter(bloomFilterName); bloomFilter.tryInit(100_967_256L, 0.000001); } public void bloomFilterAdd(String bloomFilterName, String value) { RBloomFilter
maven依赖
org.redisson redisson-spring-boot-starter3.16.4
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)