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