Redis, Memcache, Mysql区别

在使用Redis过程中,我们发现了不少Redis不同于Memcached,也不同于MySQL的特征。
(本文主要讨论Redis未启用VM支持情况)

1. Schema

MySQL: 需事先设计
Memcached: 无需设计
Redis: 小型系统可以不用,但是如果要合理的规划及使用Redis,需要事先进行类似如下一些规划

  • 数据项: value保存的内容是什么,如用户资料
  • Redis数据类型: 如String, List
  • 数据大小: 如100字节
  • 记录数: 如100万条(决定是否需要拆分)
  • ⋯⋯

上面的规划就是一种schema,为什么Redis在大型项目需要事先设计schema?因为Redis服务器有容量限制,数据容量不能超出物理内存大小,同时考虑到业务数据的可扩充性,记录数会持续增多、单条记录的内容也都会增长,因此需要提前规划好容量,数据架构师就是通过schema来判断当前业务的Redis是否需要“分库分表”以满足可扩展需求。

2. 容量及带宽规划

容量规划
MySQL: < 硬盘大小
Memcached: < RAM
Redis: < RAM

带宽规划
由于Redis比MySQL快10倍以上,因此带宽也是需要事先规划,避免带宽跑满而出现瓶颈。

3. 性能规划(QPS)

当系统读写出现瓶颈,通常如何解决?
MySQL
写: 拆分到多服务器
读: (1) 拆分 (2) 写少也可以通过增加Slave来解决

Memcached
读写: 都通过hash拆分到更多节点。

Redis:
写:拆分
读: (1) 拆分 (2) 写少也可以通过增加Slave来解决

4. 可扩展性

MySQL: 分库分表
Memcached: hash分布
Redis:也可以分库,也可以hash分布

小结

通过以上分析,Redis在很多方面同时具备MySQL及Memcached使用特征,在某些方面则更像MySQL。
由于Redis数据不能超过内存大小,一方面需要进行事先容量规划,保证容量足够;另外一方面设计上需要防止数据规模无限制增加,进而导致Redis不可扩展。
Redis需要象MySQL一样预先设计好拆分方案。

小问题

在MySQL中,通过预先建立多表或者库可以在业务增长时候将这些表或库一分为二部署到更多服务器上。
在Redis中,“分库分表”应当如何实现?有什么好的设计模式?

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
SWOC分析: Strengths: 1. 精通JAVA、SPRING、SPRINGMVC、SPRINGBOOT、SPRINGCLOUD等,有微服务开发经验优先; 2. 精通MYSQL、ORACLE、REDIS、MONGODB等NOSQL数据库,掌握GIT、SVN、MAVEN、ANT等管理工具; 3. 至少掌握一种缓存框架,如REDISMEMCACHE,有高并发、大数据处理项目经验; 4. 熟悉前端开发技术,如VUE等; 5. 具备良好的沟通能力、协调能力和问题解决能力。 Weaknesses: 1. 大专及以上学历,计算机或相关专业,相对于本科及以上学历,可能会受到一定限制; 2. 没有明确的业务背景和项目经验要求,可能需要在新项目中适应新环境。 Opportunities: 1. 随着互联网技术的发展,对Java工程师的需求不断扩大,有较好的职业发展前景; 2. 开发技术不断更新迭代,可以持续学习并且增强自身竞争力。 Challenges: 1. 需要快速适应新环境和不断变化的技术; 2. 需要在高压力、高负载的情况下保持稳定的表现。 选择排序及理由: 我会选择这个岗位,因为这个岗位的技能要求比较全面,涵盖了Java开发的各个方面,包括后端开发、数据库、缓存、前端等,这样可以全面提升自己的技能,也可以更好地理解整个项目的结构和运行机制。 虽然这个岗位对学历有一定要求,但是只要技能达到要求,学历并不是限制因素。此外,这个岗位的职业发展前景较好,也有较大的学习和发展空间。 同时,这个岗位也有一些挑战,需要不断适应新环境和技术,并且在高压力、高负载情况下保持稳定的表现。但是这些挑战也可以促进个人的成长和提升。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值