【苍穹外卖】Redis缓存菜品数据-业务逻辑分析

2024-04-25 01:44

本文主要是介绍【苍穹外卖】Redis缓存菜品数据-业务逻辑分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • Redis缓存菜品数据-业务逻辑分析
    • 1. 需求
    • 2. 需要考虑的问题
    • 3. 缓存逻辑分析
    • 4. 缓存流程图

Redis缓存菜品数据-业务逻辑分析

1. 需求

在菜品展示页面,用户点击每一个分类都会访问一次MySQL数据库数据,当大量用户使用发出大量请求时,会对MySQL数据库造成很大的压力,即读性能下降,用户端也会因为菜品信息加载速度慢导致程序使用体验差。

因此,对于这种频繁的查询数据,我们需要更高的性能,Redis数据库基于内存存储数据,读写性能很高,就可以用于缓存菜品数据。
Alt

2. 需要考虑的问题

  1. 什么类型的操作需要进行缓存?
  2. 如何保证Redis数据库和MySQL数据库的数据一致性?

3. 缓存逻辑分析

在用户端菜品展示页面,是根据每一个分类对菜品进行展示的,所以我们只需要当用户端根据分类id查询菜品信息的时候,对菜品信息进行缓存即可。

  • 查询操作:当用户端发送根据分类id查询菜品信息的请求时,先查询Redis数据库里面有没有分类下的菜品信息,有则直接从Redis数据库里面取,没有则查询MySQL数据库,然后再将该分类下的菜品信息存入缓存里面,下次用户端再进行查询的时候,就可以直接从缓存里面读取菜皮信息。
  • 更新操作:当后台管理端对菜品信息进行修改的时候,需要对缓存进行清理(该项目的策略是,考虑到修改操作的操作比较少,采取直接清空所有分类下的菜品信息缓存的方法)。
    • 具体到修改菜品起售状态
    • 菜品其它信息的修改
  • 菜品信息批量删除操作:当后台管理端对菜品信息进行批量删除操作时,不同的菜品对应的分类可能不同,清理缓存数据需要做很多冗余代码的判断,该项目采取的策略也是直接清空菜品缓存数据。
  • 添加操作:需要把添加的菜品的所属分类id下的缓存菜品信息,进行删除。

4. 缓存流程图

课程笔记

Alt

这篇关于【苍穹外卖】Redis缓存菜品数据-业务逻辑分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/933403

相关文章

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

Python给Excel写入数据的四种方法小结

《Python给Excel写入数据的四种方法小结》本文主要介绍了Python给Excel写入数据的四种方法小结,包含openpyxl库、xlsxwriter库、pandas库和win32com库,具有... 目录1. 使用 openpyxl 库2. 使用 xlsxwriter 库3. 使用 pandas 库

SpringBoot定制JSON响应数据的实现

《SpringBoot定制JSON响应数据的实现》本文主要介绍了SpringBoot定制JSON响应数据的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录前言一、如何使用@jsonView这个注解?二、应用场景三、实战案例注解方式编程方式总结 前言

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查