Redisson的基础使用(2)

布隆过滤器(Bloom Filter)
布隆过滤器一般用于解决缓存穿透的问题。主要原理是使用一组哈希函数,将元素映射成一组位数组中的索引位置。如果要检查某个元素是否在集合中时,将此元素通过所有的哈希函数,查看哈希值对应的位数组的值是否为1。如果对应的位数组的值都为1,这个元素可能在集合中,否则此元素一定不在集合中。简而言之就是:存在的元素可能存在,不存在的元素一定不存在。Redisson也提供了布隆过滤器的使用。

RBloomFilter<User> bloomFilter = redisson.getBloomFilter("xiaohei");
// 初始化布隆过滤器,预计统计元素数量为1000000,期望误差率为0.03
//精度越高,消耗空间越大
bloomFilter.tryInit(100000, 0.01);
bloomFilter.add(new User("xiaobai"));
bloomFilter.contains(new User("xiaobai")));

有序集(SortedSet)
在保证元素唯一性的前提下,通过比较器(Comparator)接口实现了对元素的排序。

RSortedSet<Integer> set = redission.getSortedSet("xiaohei");
set.add(3);
set.add(1);
set.add(2);
set.remove(1);

AtomicLong
与java中的原子类相似,可以理解为让long保持原子性

RAtomicLong r1 = redisson.getAtomicLong("user1");
atomicLong.set(3);
atomicLong.incrementAndGet();//自增一
atomicLong.get();

AtomicDouble

RAtomicDouble r2= redisson.getAtomicDouble("user2");
r2.set(2.81);
r2.addAndGet(4.11);//与4.11相加
r2.get();
Redisson是一个在Redis基础上实现的Java驻内存数据网格(In-Memory Data Grid)。它不仅提供了易用和可扩展的Redis操作接口,还提供了一系列分布式服务,例如分布式集合、分布式锁、分布式计数器、分布式对象等。 使用RedissonJava开发者可以非常方便地利用Redis提供的特性,例如数据的发布/订阅、自动过期、原子操作等。Redisson还支持Redis和主从架构、哨兵架构以及集群模式。 特性举例: 1. 分布式集合:例如RMap, RList, RSet等,支持自动序列化/反序列化。 2. 分布式锁:例如RLock,支持可重入锁、公平锁、联锁等。 3. 分布式计数器:例如RAtomicLong和RAtomicDouble。 4. 分布式服务:例如分布式ExecutorService等。 以下是使用Redisson的基本步骤: 1. 添加依赖:将Redisson的依赖添加到你的项目中。 2. 初始化配置:创建一个RedissonConfig对象,并设置Redis服务器的相关配置。 3. 创建Redisson客户端:使用配置创建一个RedissonClient实例。 4. 进行操作:通过RedissonClient实例调用各种分布式对象和服务进行数据操作。 示例代码片段: ```java // 创建配置对象 Config config = new Config(); config.useSingleServer().setAddress("redis://127.0.0.1:6379"); // 创建RedissonClient实例 RedissonClient redisson = Redisson.create(config); // 使用分布式锁 RLock lock = redisson.getLock("myLock"); lock.lock(); try { // 执行业务逻辑 } finally { lock.unlock(); } // 关闭RedissonClient实例 redisson.shutdown(); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

kk变色龙13

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

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

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

打赏作者

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

抵扣说明:

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

余额充值