2024年04月09日
1.互斥锁解决缓存穿透(缓存击穿) 通过互斥锁防止db攻击
public String get(key) {
String value = redis.get(key);
if (value == null) { //代表缓存值过期
//设置3min的超时,防止del操作失败的时候,下次缓存过期一直不能load db
if (redis.setnx(key_mutex, 1, 3 * 60) == 1) { //代表设置成功
value = db.get(key);
redis.set(key, value, expire_secs);
redis.del(key_mutex);
} else {
//这个时候代表同时候的其他线程已经load db并回设到缓存了,这时候重试获取缓存值即可
sleep(50);
get(key); //重试
}
} else {
return value;
}
}
2024年04月09日
Redis是常用基于内存的Key-Value数据库,比Memcache更先进,支持多种数据结构,高效,快速。用Redis可以很轻松解决高并发的数据访问问题;做为时时监控信号处理也非常不错。 说明:以下命令中,$符号之后为SHELL命令,>符号之后为Redis命令。
2024年04月09日
Redis 分布式锁的可重入性和防止死锁的机制是使用 Redis 命令和 Lua 脚本实现的。下面将分别介绍如何实现可重入性和防止死锁的机制,以及对其进行一定的优化和注意事项。