20241017软考架构-------软考案例3答案

每日打卡题案例3答案

3.【2018年真题】 难度:一般

阅读以下关于分布式数据库缓存设计的叙述,在答题纸,上回答问题1至问题3.(共25分)

【说明】

某企业是为城市高端用户提供高品质蔬菜生鲜服务的初创企业,创业初期为快速开展业务,该企业采用轻量型的开发架构(脚本语言+关系型数据库)研制了一套业务系统。业务开展后受到用户普遍欢迎,用户数和业务数量迅速增长,原有的数据库服务器已不能满足高度并发的业务要求。为此,该企业成立了专门的研发团队来解决该问题。张工建议重新开发整个系统,采用新的服务器和数据架构,解决当前问题的同时为日后的扩展提供支持。但是,李工认为张工的方案开发周期过长,投入过大,当前应该在改动尽量小的前提下解决该问题。李工认为访问量很大的只是部分数据,建议采用缓存工具MemCache来减轻数据库服务器的压力,这样开发量小,开发周期短,比较适合初创公司,同时将来也可以通过集群进行扩展。然而,刘工又认为李工的方案中存在数据可靠性和一致性问题,在宕机时容易丢失交易数据,建议采用Redis来解决问题。在经过充分讨论,该公司最终决定采用刘工的方案。

【问题1】(9分)

在李工和刘工的方案中,均采用分布式数据库缓存技术来解决问题。请说明分布式数据库缓存的基本概念。

表4-1中对MemCache和Redis两种工具的优缺点进行了比较,请补充完善表4-1中的空(1)~(6)。

表4-1

复制代码
Memcache	Redis

数据类型 简单Key/Value结构 (1)

持久性 (2) 支持

分布式存储 (3) 多种方式,主从、sentinel、cluster等

多线程支持 支持 (4)

内存管理 (5) 无

事务支持 (6) 有限支持

【问题2】(8分)

刘工认为李工的方案存在数据可靠性和一致性的问题,请说明原因。

为避免数据可靠性和一致性的问题,刘工的方案采用Redis作为数据库缓存,请说明基本的Redis与原有关系数据库的数据同步方案。

【问题3】(8分)

请给出Redis分布式存储的2种常见方案和Redis集群切片的几种常见方式。

【参考答案】

试题分析:

【问题1】

(1)Redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,hash等数据结构的存储。

(2)不支持

(3)Memcache服务器需要通过hash一致化来支撑主从结构

(4)redis把任务封闭在一个线程中,不支持多线程

(5)使用stabAllcation进行内存管理,按照既定的内存,将内存切割成特定的长度来存储相应的数据

(6)弱支持,只能保证事务中的每个操作连续执行

【问题2】

读数据时,先读Redis中的数据,如果Redis没有,则从原数据库读取,并同步更新Redis数据。写数据时,先写入原数据库中,并同步更新至Redis中。

【问题3】

主从、Cluster

客户端分片、Twemproxy、RedisCluster、Proxy+RedisCluster

相关推荐
oo哦哦2 分钟前
矩阵运营的智能风控体系:2026年平台规则下的合规技术架构
人工智能·矩阵·架构
high20115 分钟前
【架构】-- Mysql delete vs truncate 深度解析
数据库·mysql·架构
2601_957787587 分钟前
AI数字人驱动的矩阵内容生产:2026年技术架构与人效革命
人工智能·矩阵·架构
上海云盾第一敬业销售11 分钟前
DDoS防护解决方案架构解析:保障网站安全的新利器
安全·架构·ddos
靠谱品牌推荐官13 分钟前
【高性能工程】每秒万次物联网数据高频握手:如何设计一套抗丢包的工业级小程序后端微服务架构?
物联网·小程序·架构
fengxin_rou27 分钟前
【Redis 位图分片计数详解】:原理、实战架构与避坑最佳实践
数据库·redis·架构·bitmap
靠谱品牌推荐官28 分钟前
【高并发实战】如何基于缓存穿透治理机制设计一套高可用的小程序本地缓存中台架构?
缓存·小程序·架构
沪漂阿龙30 分钟前
Spring Cloud 面试题深度解析:微服务架构、注册中心、配置中心、Gateway、OpenFeign、负载均衡、熔断降级全攻略
spring cloud·微服务·架构
Mininglamp_27181 小时前
开源端侧 AI Agent 全栈架构解析:Mano-P 模型 + Cider 推理加速 + AFK 自动构建
人工智能·架构·开源·agent·mac·apple silicon·gui agent
fake_ss1989 小时前
AI时代学习全栈项目开发的新范式
java·人工智能·学习·架构·个人开发·学习方法