随笔分类 - 中间件
Java中间件相关
摘要:缓存雪崩:同一时间段内大量缓存失效或Redis服务宕机,导致大量请求到达数据库,给数据库带来巨大压力。 解决方案: 给不同的Key的TTL(存活时间)添加一个随机值 Redis宕机时:利用Redis集群提高服务可用性(哨兵模式、集群模式) 给缓存业务添加降级限流策略(保底策略,也可以解决穿透、击穿、
阅读全文
摘要:缓存击穿:缓存中一个热点数据过期或失效时,由于该数据非常受欢迎,会有大量请求直接打到数据库上,导致数据库负载增大、相应变慢甚至瘫痪。 解决方式: 互斥锁 在查询数据库之前首先获取分布式锁,更新redis之后再释放锁,可以保证数据的强一致性。 优缺点: 优点:强一致性 缺点:性能差 逻辑过期 数据本身
阅读全文
摘要:缓存穿透:查询一个不存在的数据,Mysql查询不到也没有写入缓存,导致每次请求都会查询数据库。(比如恶意请求) 解决方案: 缓存空数据:返回数据为空时仍然缓存(但是需要加过期时间)。 优点:简单 缺点:消耗内存,可能存在数据不一致情况。 布隆过滤器 布隆过滤器使用Bitmap(位图)来记载一个数据是
阅读全文
摘要:最近学习了 sharding sphere 中的jdbc组件,此文作为学习记录方便以后复习。 中间件官网:Apache Sharding Sphere 学习准备 快速开始 分表 创建库表: CREATE DATABASE `db_device_0` DEFAULT CHARACTER SET utf
阅读全文