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;

/**
 * 
 * @author kk
 * @Description Redisson相关配置
 */
@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;

/**
 * @Author: kk
 * @Description: redis工具类
 **/
@Component
public class RedisUtil {
	@Autowired
	RedissonClient redissonClient;

   /**
	 * 布隆过滤器初始化
	 * 
	 * @param bloomFilterName 过滤器名称
	 */
	public void bloomFilterInit(String bloomFilterName) {
		RBloomFilter<String> bloomFilter = redissonClient.getBloomFilter(bloomFilterName);
		bloomFilter.tryInit(100_967_256L, 0.000001);
	}
	
	/**
	 * 布隆过滤器添加数据
	 * 
	 * @param bloomFilterName 过滤器名称
	 * @param value           要添加的值
	 */
	public void bloomFilterAdd(String bloomFilterName, String value) {
		RBloomFilter<Object> bloomFilter = redissonClient.getBloomFilter(bloomFilterName);
		bloomFilter.add(value);
	}
	
	/**
	 * 布隆过滤器数据统计
	 * 
	 * @param bloomFilterName
	 * @param value
	 */
	public boolean bloomFilterContains(String bloomFilterName, String value) {
		RBloomFilter<String> bloomFilter = redissonClient.getBloomFilter(bloomFilterName);
		return bloomFilter.contains(value);
	}
}

配置文件

spring:
  #redis配置
  redis:
    host: 127.0.0.1
    password: 123456
    port: 6379
    timeout: 5000

maven依赖

<dependency>
   <groupId>org.redissongroupId>
   <artifactId>redisson-spring-boot-starterartifactId>
   <version>3.16.4version>
dependency>

你可能感兴趣的:(java)