缓存
缓存是什么
缓存就是数据交换的缓冲区(称为Cache),是存储数据的临时地方,一般读写性能较高。
CPU的处理速度远远超过内存和硬盘的读写速度,因此在CPU中预留了一部分缓存,CPU可以直接取缓存中的内容,速度远超内存和硬盘。
在Web应用开发过程,也有很多缓存技术:
- 浏览器缓存:用户请求直接查询浏览器缓存,如果有直接展示。
- 应用层缓存:浏览器中缓存未命中,则查询应用层缓存,如果有就无需查询数据库,直接返回。
- 数据库缓存:应用层缓存未命中,则查询数据库缓存(例如索引),在内存中快速查询,如果有就直接返回,无需访问磁盘。
- CPU缓存。
- 硬盘缓存。
缓存的利弊
好处:
- 降低后端负载:不使用缓存时,查询数据库需要硬盘IO,速度慢。如果使用缓存,则不需要进行硬盘IO。
- 提高读写效率,降低响应时间。缓存的读写速度比磁盘IO快。
坏处:
- 数据一致性问题:数据位于内存中(Redis),读写操作内存中的副本。此时如果数据库(MySQL)中的数据还是旧的,则读取磁盘上的数据会发生数据不一致。
- 代码维护成本:为了保持数据一致性,需要进行很多维护操作。
- 运维成本:缓存的使用往往需要集群部署,运维成本较高。
对于硬盘来说,内存就是硬盘的缓存。对于内存来说,CPU的寄存器就是内存的缓存。对于CPU寄存器(分级缓存)来说,L1是L2的缓存,L2是L3的缓存。