Redis

Redis: Remote Dictionary Server 远程字典服务器
是一个高性能的key-value分布式内存数据库,基于内存运行,并支持持久化的Nosql数据库

三个特点:
1、支持数据持久化,可以将内存的数据保存在磁盘上,重启的时候可以再次加载使用
2、不仅仅支持简单的key-value类型的数据,还提供list,set,zset,hset等数据结构的存储
3、支持数据备份,即master-slave模式的数据备份

1、SpringBoot2 以后默认使用Lettuce作为操作redis的客户端,它使用netty进行网络通信
2、Lettuce的bug导致netty堆外内存溢出, netty如果没有指定堆外内存,默认使用java程序的最大内存
   可以通过-Dio.netty.maxDirectMemory进行设置

Redis使用Lua脚本删除锁

String lockName = "lockName111";
String lockVal = "lockValue111111";
        
String script = "if redis.call('get', KEYS[1]) == ARGV[1] then return redis.call('del', KEYS[1]) else return 0 end";
stringRedisTemplate.execute(new DefaultRedisScript<Long>(script, Long.class), Arrays.asList(lockName), lockVal);
 

Redisson
    1、加锁
    lock.lock(); //阻塞式等待,默认加锁都是30s
       1、锁的自动续期,如果业务时间超长,运行期间每隔10s(30/3)给锁自动续期
       2、加锁的业务只要运行完成,就不会给当前锁续期,即使不手动解锁,锁默认在30s以后自动删除
    
    lock.lock(10, TimeUnit.SECONDS);//10秒自动解锁,在设置时自动解锁时间一定要大于业务执行时间
        1、加锁时间到期后不会自动续期
        2、如果未指定锁的超时时间,就使用30*1000[LockWatchdogTimeout(看门狗默认时间)]
            只要占锁成功,就会启动一个定时任务(重新给锁设置过期时间,新的过期时间就是看门狗的默认时间)
            internalLockLeaseTime 看门狗时间/3=10s

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值