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

相关推荐
HsuYang2 小时前
Vite源码学习(十二)——热更新(下)
前端·javascript·架构
BlueBirdssh2 小时前
ARM SOC 架构系统M系、R系、A系
arm开发·架构
CodeJourney.4 小时前
WPS携手DeepSeek:开启智能办公新时代
数据库·人工智能·算法·架构
uhakadotcom6 小时前
Next.js中生成sitemap的简单方法
前端·面试·架构
车载诊断技术21 小时前
电子电气架构 --- 电子电器新技术及发展趋势
网络·架构·汽车·电子电器框架·车载充电器(obc)·电子电器新技术及发展趋势
呱牛do it21 小时前
【系列专栏】银行IT的云原生架构-混合云弹性架构 13
微服务·云原生·金融·架构
uhakadotcom1 天前
约束求解领域的最新研究进展
人工智能·面试·架构
文军的烹饪实验室1 天前
我国有哪些芯片使用的是arm架构处理器
arm开发·架构
微学AI1 天前
Deepseekv3原理架构中的数学公式,通过高度概括实现快速入门
开发语言·人工智能·python·架构·deepseek
martian6651 天前
【Java高级篇】——第13篇:深入探讨设计模式与Java实践
java·开发语言·架构