【缓存设计】最基础的多级缓存,是否合适,应该怎么设置?

WBOY
Lepaskan: 2023-03-01 17:14:01
asal
1582 orang telah melayarinya

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

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

现在初步构想:

<code>浏览器缓存-》本地文件缓存-》内存缓存(Redis)-》Db
</code>
Salin selepas log masuk
Salin selepas log masuk

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

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

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

  3. 内存缓存

  4. Db

我的问题是:

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

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

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

回复内容:

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

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

现在初步构想:

<code>浏览器缓存-》本地文件缓存-》内存缓存(Redis)-》Db
</code>
Salin selepas log masuk
Salin selepas log masuk

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

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

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

  3. 内存缓存

  4. Db

我的问题是:

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

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

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

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

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

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

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan