阅读以下关于分布式数据库缓存设计的叙述,在答题纸上回答以下问题。 【说明】 某企业是为城市高端用户提供高品质蔬菜生鲜服务的初创企业,创业初期为快速开展业务,该企业采用轻量型的开发架构(脚本语言+关系型数据库)研制了一套业务系统。业务开展后受到用户普遍欢

admin2019-10-09  38

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

选项

答案 可靠性方面Memcache不支持数据持久化,断电或重启后数据丢失;一致性方面,Memcache本身不支持分布式,通过使用Hash一致性算法,可以实现分布式存储,但各台Memcache服务器之间互不通信,数据一致性无法保障。 Redis与关系数据库同步方案对于读操作,先读Redis。若没有,则读关系数据库并将值写入Redis;对于写操作,写关系数据库成功后更新Redis中的值。

解析
转载请注明原文地址:https://jikaoti.com/ti/2t67FFFM
0

最新回复(0)