设为首页 收藏本站
查看: 1075|回复: 0

[经验分享] redis,memcache,mongodb对比

[复制链接]

尚未签到

发表于 2018-10-27 10:24:21 | 显示全部楼层 |阅读模式
  这段时间对memcache,redis,mongodb 3种nosql进行了熟悉,简单的总结了下。
  1.从3者的性能来看,memcache性能是最好的,redis次之(redis有单进程限制,会碰到cpu 100%的限制,这个也比较难比较,一个多进程,一个单进程)
  2.从ha和scale out的角度来看,mongodb的灵活性和可用性最高。。memcache本身不怎么支持高可用。。需要前端实现persistencehash或者proxy。。
  Redis虽然支持m-s和m-s-s的结构,但是其对网络的依赖比较大,m-s之间的丢包也可能导致一次全量的镜像产生。
  Redis和memcache的横向扩展方式是一样的,但是单个的redis比较容易遇到cpu的瓶颈
  3.从存储的数据类型来看,mongodb最丰富,而且操作也比较灵活,支持类sql的查询。。memcache是纯粹的key-value,数据结构单一
  4.从数据的备份角度来看,memcache数据备份不太方便,需要3方工具,redis可以用持久化,mongodb的数据备份方法则比较多。
  总结来说;
  1.如果业务对数据的持久化没什么要求,数据结构比较单一,目的是做前端缓存的话,memcache会提供比较好的性能表现
  2.如果业务对数据的持久化有要求,需要备份,支持读写分离的话,用redis做缓存比较合适(也可以做一部分的后端存储)
  3.mongodb主要是用在大量数据的后端存储上,支持autosharding和自动故障转移,可用性比较高和hadoop群集类似
  目前我们对nosql的使用还不太完善,包括一些监控,比如redis的定时monitor监控。对性能的分析也基本没有。。
  比如redis和mongodb都是有slow log的,但是我们线上都没有开启更没有进行分析。。。这个可能是后续要做的事情。。
  下面是一个简单的对比表:
对比参数memcacheredismongodb数据库类型纯粹的key-value数据库,数据结构单一结构化数据库对象数据库支持数据类型stringstring,list,sort,sorted,hash丰富的数据表达,索引,类似于关系型数据库可用性没有数据冗余机制,使用一致性hash增加可用性支持ms,mss结构,slave重连主节点会导致一次全量同步产生,影响性能和效率。可以实现读写分离,slave重连使用全量数据,性能和效率会有问题,不支持自动sharding,需要程序上实现一致性hash支持ms,支持replication set,set可以自动故障转换,支持autosharding持久化支持数据完全放在内存中,没有持久化支持支持持久化,快照持久化和aof持久化1.8版本开始采用binlog方式支持持久化的可靠性内存空间优化最大内存限制,LRU算法淘汰(可选)独立的vm机制,最大内存限制,数据ttl过期设置,内存淘汰(可选)依赖于操作系统的vm管理机制,使用内存映射文件,把剩余内存作为缓存使用,没有最大内存限制,数据存在文件系统上和内存是否是多线程是,可以通过-t控制进线程数单线程多线程性能15W/s的GET,11W/s的SET单个实例qps:8.5W左右(GET/SET)(RH2285)单个qps:3.5W左右(GET/SET)(RH2285)事务支持并发场景下,用cas保证一致性事务支持比较弱,保证每个事务操作连续执行,如果一个操作失败,不会回滚。使用乐观锁实现cas。不支持事务数据分析简单的get查询功能简单查询功能,支持对集合和hash的操作等查询方便,有类似于sql的语法,支持条件查询应用场景常作为前端缓存缓存和数据存储,队列大数据量存储feature支持使用pipeline减少查询次数auto sharding,故障自动切换,mapreduce支持,大文件下的GridFs文件系统安全性问题目前没有身份验证支持密码验证(requirepass)支持collection级别的身份验证(auth)数据备份和还原数据存放于内存中,不方便备份和还原(stats cachedump)可以使用持久化做备份和还原mongodump倍份,mogorestore还原。数据导出:mongoexport,mongoimport,导出数据支持csv格式slowlog相关没有slowlog相关的设置支持slowlog,slowlog存在于数据库中,使用slowlog get获取相关日志,slowlog的大小有限制,超过后会删除旧的支持slowlog(profiling),slowlog存在于system.profile(capped collection)的collection中状态查看statsinfomongostat,db.serverStatus(),db.stats(),rs.statsu()等当前操作查看monitormongosniff,db.currentOp()tunning1.object>2.object 的expires设置(缓存应该具有超时的特点)  3.适合数据处理后的缓存,不适合缓存后的处理输出
1.开启vm,将不常用的value值给交换到磁盘上  2.尽量将数据存放在内存中3.前端使用proxy或persistence
  hash来实现均衡访问4.使用master-slave结构,做读写分离
  5.大数据量时持久化数据dump时影响服务,应该放在slave端做6.使用pipeline聚合访问7.网卡bonding
1.索引相关(读多写少时) 2.explain解析查询  3.限定返回条目(limit)
  4.只查看指定需要字段,不查询所有字段
  5.使用capped collection (特殊业务)
  6.使用replsets,扩展整体集群能力


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-627031-1-1.html 上篇帖子: MongoDB实战(10)Replica Sets 副本集(下) 下篇帖子: mongodb 使用forEach 和js自定义函数 修改指定列的第19个字符
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表