开发者社区> 问答> 正文

数据访问层(DAL)怎么优雅的协调存取缓存数据库(如redis)和持久数据库(如mysql)?

假设dal用php举例。

原来使用php单独操作mysql,现在需要压榨服务器,考虑增加一个redis,但同时面对两个数据源的存取策略产生了疑惑,希望帮助梳理一下。

用伪代码解释一下更好

展开
收起
爵霸 2016-03-09 13:19:43 3479 0
1 条回答
写回答
取消 提交回答
  • 仅仅把redis当做缓存, 没必要写在DAL里吧(我不知道DAL的意思,只用过DAO、AR,ORM,听名字都是类似的东西?),就仅仅以缓存的形式去拓展它,比如继承你Cache类,如果还有用作永久存储需求,去继承DAL类,用redis给它实现出来,如果用做队列、或交集并集、计数器等等,同样去通过redis数据库去实现既有的接口。

    最后用一个通用入口文件,通过构造方法调用不同的实现。

    伪代码不会写,既然PHP直接贴开源项目吧Yii2-redis, 看看其中ActiveRecord.php与Cache.php,大概想法就是这样。

    2019-07-17 18:55:53
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Redis在唯品会的应用实践——架构演进与功能定制 立即下载
微博的Redis定制之路 立即下载
云数据库Redis版的开源之路 立即下载

相关镜像