springBoot redisson使用布隆过滤器

springBoot redisson使用布隆过滤器,第1张

springBoot redisson使用布隆过滤器

关于布隆过滤器原理这里不做过多解释,如不明白可以先查询资料搞清楚原理与使用场景再来看本篇文章,开头我要先指出几个问题

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 bloomFilter = redissonClient.getBloomFilter(bloomFilterName);
		bloomFilter.add(value);
	}
	
	
	public boolean bloomFilterContains(String bloomFilterName, String value) {
		RBloomFilter bloomFilter = redissonClient.getBloomFilter(bloomFilterName);
		return bloomFilter.contains(value);
	}
}
 

maven依赖


   org.redisson
   redisson-spring-boot-starter
   3.16.4

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5434318.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-11
下一篇 2022-12-11

发表评论

登录后才能评论

评论列表(0条)