为什么选择MongoDB?

为啥用MongoDB?

赶NoSQL时髦? 
Auto-shard等激动人心的特性? 
•No! 08年,还都是浮云。 
最初的想法是寻找一个可靠的分布式K/V解决MySQL的问题。

NoSQL(NoSQL = Not Only SQL ),意即反SQL运动,是一项全新的数据库革命性运动,早期就有人提出,发展至2009年趋势越发高涨。NoSQL的拥护者们提倡运用非关系型的数据存储,相对于目前铺天盖地的关系型数据库运用,这一概念无疑是一种全新的思维的注入。

所以说,NoSQL不仅仅是产品,更是一项运动!

原来的架构

•MySQL(Percona),

Master-Master-Slaves

•HA:MMM

新需求

  • 能够适应多数据源
  • 需要灵活,不确定的schema:不同模型的字段不定,属性不定
  • 属性更新频繁
  • 服务器等硬件资源有限

如何解决?

原有MySQL的方案:

  • 使用文本字段,JSON存储
  1. schema自由度高
  2. 更新容易,直接检索困难
  • 使用关联表
  1. schema自由度有限,类型控制
  2. 更新频繁,query缓存失效

新思路

继续使用Memcached?

  • 缓存失效,内存不足

决定:寻找Memcached替代品

  • 能够持久化的分布式KV

选型条件

  • 同时有PHP/Perl/DotNet/JAVA的良好客户端支持
  • 性能和Memcached相差不要太
  • 支持分布式集群
  • 低碳环保,节约资源
  • 文档清晰,有成功案例

一些候选者

  • Flare
  • Repcached
  • Redis
  • TC/TT

最初的选择

选中Flare:

  • 内置cluster看起来很美好,可靠性有保 
  • 使用Memcached协议,现有改动小

代价

项目开发1个月后:

  • 官方更新显示似乎并非如此可靠
  • 水土不服:

(1)个人能力有限,无法解决一些灵异事件

(2)没有开发者社区

(3)不懂日文

新的候选者

  • Cassandra:技术实力无法支撑,用不起
  • CouchDB:灵活,但性能口碑似乎不佳

重新选择

MongoDB:

  • 读写性能中庸,比Redis逊色
  • Document模型令人满意
  • 内置操作没有Redis惊喜,基本够用
  • MySQL类似的集群机制,上手方便
  • 某些MySQL的优化部署经验可以复用

胆子大一点

MySQL +MongoDB?

  • 多余:很多MySQL的操作MongoDB均 
    可实现
  • 同时维护MySQL <=> MongoDB 的数 
    据,代码逻辑有些复杂
  • 人员流失,培训新人表示鸭梨大

胆子再大一点

能否彻底抛弃MySQL?

  • Transaction?可以没有
  • Joins? 原本少用,可以没有
  • 数据一致性:不太高

胆子再更大一点

好吧,试试:

  • 拿一个旧项目开刀
  • 1人1个星期完成90%代码移植
  • 原有35个table => 10 collection
  • 开发过程很happy!

MongoDB,就是它了

一举两得的加分项:GridFS

  • 简单,符合我们的要求
  • 无需再考虑分布文件系统
  • 放弃了原来的MogileFS,减轻运维压 

综上原因,选对了!

  • SourceForge等一些大站应用增强信心
  • 分享的信息逐渐丰富
  • 10gen核心团队在mailing-list快速响应, 
    有问必答
  • NoSQL开始受到追捧,MongoDB的口 
    碑良好

本文参收集网络资料整理,作为我选择MongoDB的一个参考。

为什么选择MongoDB?的更多相关文章

  1. 开篇有益:为什么选择MongoDB?

    为啥用MongoDB? 赶NoSQL时髦? Auto-shard等激动人心的特性? •No! 08年,还都是浮云. 最初的想法是寻找一个可靠的分布式K/V解决MySQL的问题. NoSQL(NoSQL ...

  2. 大数据时代的数据存储,非关系型数据库MongoDB

    在过去的很长一段时间中,关系型数据库(Relational Database Management System)一直是最主流的数据库解决方案,他运用真实世界中事物与关系来解释数据库中抽象的数据架构. ...

  3. 了解mongodb

    本文大纲 基础了解mongodb(mongodb介绍,跟其他nosql区别,跟内存服务器区别等,使用场景) 在使用前,强力建议看哈http://wenku.baidu.com /link?url=lu ...

  4. MongoDB自学笔记2---1.2 初识MongoDB

    1.2.1MongoDB简介 MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案. MongoDB是一个介于关系数据库和非关系数据库之 ...

  5. 大数据时代的数据存储,非关系型数据库MongoDB(一)

    原文地址:http://www.cnblogs.com/mokafamily/p/4076954.html 爆炸式发展的NoSQL技术 在过去的很长一段时间中,关系型数据库(Relational Da ...

  6. Asp.Net Core Web Api图片上传(一)集成MongoDB存储实例教程

    Asp.Net Core Web Api图片上传及MongoDB存储实例教程(一) 图片或者文件上传相信大家在开发中应该都会用到吧,有的时候还要对图片生成缩略图.那么如何在Asp.Net Core W ...

  7. 非关系型数据库MongoDB

    爆炸式发展的NoSQL技术 在过去的很长一段时间中,关系型数据库(Relational Database Management System)一直是最主流的数据库解决方案,他运用真实世界中事物与关系来 ...

  8. MongoDB拥有SSD秒杀高富帅使用过程分享

    [IT168现场报道]2013年4月18-20日,第四届中国数据库技术大会(DTCC 2013)在北京福朋喜来登酒店拉开序幕.在为期三天的会议中,大会将围绕大数据应用.数据架构.数据管理(数据治理). ...

  9. HowToDoInJava 其它教程 1 &#183; 翻译完成

    原文:HowToDoInJava 协议:CC BY-NC-SA 4.0 欢迎任何人参与和完善:一个人可以走的很快,但是一群人却可以走的更远. ApacheCN 学习资源 目录 Maven 教程 如何在 ...

随机推荐

  1. monkey命令详解

    标准的monkey 命令 adb shell monkey [options] <eventcount> 例如: adb shell monkey -v    产生500次随机事件,作用在 ...

  2. 软件开发V型号

    RAD(rap application development),就是软件开发过程中的一个重要模型,称为高速应用开发模型.其模型构图形似字母V,所以又称V模型.      他通过开发和測试同一时候进行 ...

  3. HDU 3376 &amp;&amp; 2686 方格取数 最大和 费用流裸题

    题意: 1.一个人从[1,1] ->[n,n] ->[1,1] 2.仅仅能走最短路 3.走过的点不能再走 问最大和. 对每一个点拆点限流为1就可以满足3. 费用流流量为2满足1 最大费用流 ...

  4. hdu 3874

    求一个序列中全部数字的和,当中数值同样的仅仅能计算一次. 先储存全部的请求,然后依照它们的右边界排序,在查询的同一时候更新区间.这里事实上有一点点DP的味道,在它进行某个查询之前,保证全部的反复数字( ...

  5. 【百度地图API】如何制作自定义样式的公交导航结果面板?

    原文:[百度地图API]如何制作自定义样式的公交导航结果面板? 摘要: 百度地图API有默认的公交导航结果面板,但样式比较单一:而百度地图上的结果面板就比较美观.如何利用百度地图API来制作一个比较美 ...

  6. php exit、return、break、continue之间的差别,具体介绍

    相信大家在php开发中有几个经常使用的停止程序和循环的keyword的误区( exit.return.break.continue) exit 退出全部脚本,是个函数 return 语言结构的使用方法 ...

  7. MVC 验证码

    验证码类 public class VerifyCode { public string checkCode = String.Empty; public byte[] BuildImg() { in ...

  8. sql级联删除

    原文:sql级联删除 功能:在删除主表时,自动删除副表(外键约束)相应内容 删除包含主键值的行的操作,该值由其它表的现有行中的外键列引用.在级联删除中,还删除其外键值引用删除的主键值的所有行. 如: ...

  9. Linq to Sql:N层应用中的查询(下) : 根据条件进行动态查询

    原文:Linq to Sql:N层应用中的查询(下) : 根据条件进行动态查询 如果允许在UI层直接访问Linq to Sql的DataContext,可以省去很多问题,譬如在处理多表join的时候, ...

  10. 寻找单向链表的倒数第k个节点

    题目: 输入一个单向链表,输出这个单向链表的倒数第k个节点 template<class T> class ListNode { public: T Data; ListNode<T ...