分布式缓存与本地缓存的区别
上一篇 <<<Marshalling在Netty中的使用
下一篇 >>>Ehcache基础知识
为什么缓存速度比数据库速度快
因为关系数据库mysql、sqlserver数据存放在硬盘中,查询实现io操作,速度较慢。
而缓存技术是直接从内存中读取的,速度较快。
缓存类型
Jvm内置缓存框架 ehcache(底层同步机制很差,持久化在硬盘上)、OScache也有持久化机制,唯独memcache没有持久化,市面上memcache的持久化是大神改造的。
非关系数据库Redis是完全开源免费的,是一个高性能的key-value数据库,支持持久化防止宕机,同时对空间大小有阈值设置,会有淘汰策略,目前市面上主流的数据库Redis、Memcache、Tair(淘宝自研发)。
分布式缓存与本地缓存的区别
分布式缓存一致性更好一点,本地缓存 每个实例都有自己的缓存,可能会存在不一致的情况。
本地缓存会占用堆内存,影响垃圾回收、影响系统性能。分布式缓存两大开销会导致其慢于本地缓存,网络延迟和对象序列化
进程内缓存适用于较小且频率可见的访问场景,尤其适用于不变对象,对于较大且不可预见的访问,最好采用分布式缓存。
推荐阅读:
<<<Ehcache基础知识
<<<SpringBoot整合Ehcache
<<<Redis的5种数据类型
<<<Redis存放实体对象的方式及区别
<<<Redis的应用场景汇总
<<<Redis高效及线程安全的真正原因
<<<Redis为啥要分为16个库
<<<RDB和AOF持久化方式的区别
<<<Redis与数据库的一致性解决方案
<<<SpringBoot整合Redis的注解版本完成数据缓存
<<<Redis的淘汰策略
<<<Redis的事务操作(Mult和Watch)知识点
<<<Redis的过期机制使用场景示例
<<<Redis实现分布式锁的原理分析
<<<Redis分布式锁的实现代码示例
<<<使用Redisson工具实现分布式锁
<<<Redis集群模式之主从复制原理及存在的缺陷
<<<Redis集群模式之哨兵模式
<<<Redis集群模式之Cluster去中心化分片集群
<<<Linux环境下安装单机Redis
<<<Redis Cluster集群环境搭建
<<<Redis Cluster如何动态扩容与缩容
<<<Redis Cluster主从节点自动切换
<<<Redis集群模式的类型和缺陷汇总
<<<Redis缓存的穿透、击穿和雪崩效应
<<<Redis解决穿透击穿问题时使用的布隆过滤器知识点
<<<Redis与MySQL的数据同步解决方案
<<<阿里云的Canal框架实现Redis与Mysql同步原理及代码示例
<<<阿里云的Canal框架配置
<<<Redis官方提出的redlock分布式锁
<<<Redis的调优设置
<<<Redis常见问题汇总