• 技术文章 >后端开发 >php教程

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

    2016-12-01 00:25:37原创912

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

    环境:
    负载均衡、主从分离、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的集中式缓存要更加优秀

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:http file redis php
    上一篇:php 如何以json格式存储session,而不是默认的内置编码? 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • 一文解析PHP元转分的错误示范(附代码实例)• PHP+Socket系列之实现websocket聊天室• PHP+Socket系列之实现客户端与服务端数据传输• PHP+Socket系列之IO多路复用及实现web服务器• 一文详解PHP用流方式实现下载文件(附代码示例)
    1/1

    PHP中文网