关于布隆过滤器原理这里不做过多解释,如不明白可以先查询资料搞清楚原理与使用场景再来看本篇文章,开头我要先指出几个问题
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) {
RBloomFilter bloomFilter = redissonClient.getBloomFilter(bloomFilterName);
bloomFilter.tryInit(100_967_256L, 0.000001);
}
public void bloomFilterAdd(String bloomFilterName, String value) {
RBloomFilter
maven依赖
org.redisson redisson-spring-boot-starter 3.16.4



