近日想给我们系统,做一套一级级下来的缓存机制。但是总感觉缺了点什么。

环境:
负载均衡、主从分离、Redis单机(日后可多机)

现在初步构想:

浏览器缓存-》本地文件缓存-》内存缓存(Redis)-》Db
登录后复制
登录后复制

用户在访问Web应用后,给其设置浏览器缓存,然后设置本地的文件缓存和内存缓存。
其他用户在访问后,我认为步骤如下:

  1. 检查是否有浏览器缓存

  2. 检索本地机器是否有文件缓存

  3. 内存缓存

  4. Db

我的问题是:

但是觉得里面某一步骤少了点什么,或者觉得里面的(多级)缓存失效时间很难取舍。

并且,本地的文件缓存{检查过期时间、读取(删除、生成)文件}与直接跳到内存缓存(Redis)的一次连接相比又是否值得?

因此想要咨询下我这基础的缓存机制,是否合适或者有什么弊端可以改进的,感谢!

回复内容:

近日想给我们系统,做一套一级级下来的缓存机制。但是总感觉缺了点什么。

环境:
负载均衡、主从分离、Redis单机(日后可多机)

现在初步构想:

浏览器缓存-》本地文件缓存-》内存缓存(Redis)-》Db
登录后复制
登录后复制

用户在访问Web应用后,给其设置浏览器缓存,然后设置本地的文件缓存和内存缓存。
其他用户在访问后,我认为步骤如下:

  1. 检查是否有浏览器缓存

  2. 检索本地机器是否有文件缓存

  3. 内存缓存

  4. Db

我的问题是:

但是觉得里面某一步骤少了点什么,或者觉得里面的(多级)缓存失效时间很难取舍。

并且,本地的文件缓存{检查过期时间、读取(删除、生成)文件}与直接跳到内存缓存(Redis)的一次连接相比又是否值得?

因此想要咨询下我这基础的缓存机制,是否合适或者有什么弊端可以改进的,感谢!

  1. 多级缓存能减少系统的压力,并且极大减少了rt,但是有一个方面需要考虑的是多级缓存的管理,这一点作者在文章中也有提及,这是用多级缓存所避免不了的问题。至于怎么让多级缓存失效,可以尝试用本地定时器隔断时间刷一遍缓存

  2. 文件缓存其实可以换成本地内存缓存,设计成文件缓存也是可以的,但是当量很大的时候本地磁盘I/O,恐怕扛不住至于和网络开销到底哪个效率更加优,需要根据实际情况去压测一下

  3. 多级缓存更多的解决是,缓存穿透与程序的健壮性,当集中式缓存出现问题的时候,我们的应用能够继续运行;一些热点数据做成内存缓存,就不用访问集中式缓存,可以减少集中式缓存的压力。所以在这个方面文件缓存比Redis的集中式缓存要更加优秀

09-18 04:32