mongodb初识

 
nosql介绍:
  当前的NoSQL并不是指没有sql,纯粹用非关系数据库,而是指Not Only Sql。因为一般来说,仅仅使用非关系数据库很难完成一个项目的开发,多数是需要关系数据库跟非关系数据库相互配合来完成。nosql本质也是一种数据库技术,相对于关系库,它不会遵循一些约束,比如sql标准,ACID属性,表结构等,一般性能很强, 但往往在某些重要特性上有缺失,比如事务。
nosql优缺点:

优点
缺点
满足对数据库的高并发读写
一般不支持事务
对海量数据的高效存储和访问
实现复杂SQL查询比较复杂
对数据库高扩展性和高可用性
运维人员数据维护门槛较高
灵活的数据结构,满足数据结构不固定的场景
目前不是主流的数据库技术
nosql分类:
序号
类型
应用场景
典型产品
1
key-value存储
缓存,处理高并发数据访问
redis,memcached
2
列式数据库
分布式文件系统
Cassandra,hbase
3
文档型数据库
web应用,并发能力较强,表结构可变
mongodb
4
图结构数据库
社交网络,推荐系统,关注构建图谱
infogrid,neo4j
mongodb介绍:
  mongodb是一个高性能开源数据库,是目前nosql中最热门的数据库之一,基于c++开发,是nosql中功能最丰富,最像关系数据库的。
   特性
    1、面向集合文档的存储:适合存储Bson(json的扩展)形式的数据;
    2、格式自由,数据格式不固定,生产环境下修改结构都可以不影响程序运行;
    3、强大的查询语句,面向对象的查询语言,基本覆盖sql语言所有能力;
    4、完整的索引支持,支持查询计划;
    5、支持复制和自动故障转移;
    6、支持二进制数据及大型对象(文件)的高效存储;
    7、使用分片集群提升系统扩展性;
    8、使用内存映射存储引擎,把磁盘的IO操作转换成为内存的操作;
   基本概念
    实例:操作系统上运行库的进程及节点集,一个实例可以有多个库;通俗点说,可以认为就是我们电脑上装的那个应用程序。
    库:多个集合组成数据库,每个数据库都是完全独立的,有自己的用户信息,权限信息,独立的存储文件集。
    集合:集合是一组文档,类似于关系库中的表的概念。
    文档:文档是mongodb中的最小数据集单位,其基本概念为:由多个键值对有序组合在一起的数据单元。类似于关系库中的行。
    字段:类似于关系库中的列的概念。
   该不该用mongodb?
    并没有某个业务场景必须要用mongodb才能解决,但使用mongodb通常能让你以更低的成本解决问题。
应用特征
yes/no
应用不需要事务及复杂join支持
必须yes
新应用,需求会变,数据模型无法确定,想快速迭代开发
应用需要2000-3000以上的读写qps(更高也可以)
应用需要TB甚至PB级别的数据存储
应用发展迅速,需要能快速水平扩展
应用需要99.999%高可用
应用要求存储的数据不能丢失
应用需要大量的地理位置查询、文本查询
  以上描述如果排除掉 第一个事务及join是必须的yes,后面的描述有1个yes,则可以考虑选择mongodb,两个及以上的yes,选择mongodb应该是没什么问题的。mongodb是不支持事务的,因此对事务有强要求的场景是肯定无法使用的,再者,虽然都说操作类似于sql,非常简单,但实际使用你会发现差别还是挺大滴(是可以按照sql理解,但语法绝对跟sql没半毛钱关系),对于复杂的join操作,mongo的查询条件拼接也是挺折腾的。
   什么场景不能使用mongodb
    1、高度事务性系统:例如银行、财务等系统;mongodb对事务支持很弱;
    2、传统的商业智能应用:特定问题的数据分析,多数据实体关联,涉及到复杂的、高度优化的查询方式;
    3、使用sql方便的时候;数据结构相对固定,使用sql进行查询统计更加便利的时候;
   几个使用场景
    MongoDB 的应用已经渗透到各个领域,比如游戏、物流、电商、内容管理、社交、物联网、视频直播等,以下是几个实际的应用案例:
    1、游戏场景,使用 MongoDB 存储游戏用户信息,用户的装备、积分等直接以内嵌文档的 形式存储,方便查询、更新
    2、物流场景,使用 MongoDB 存储订单信息,订单状态在运送过程中会不断更新,以 MongoDB 内嵌数组的形式来存储,一次查询就能将订单所有的变更读取出来。
    3、社交场景,使用 MongoDB 存储存储用户信息,以及用户发表的朋友圈信息,通过地理 位置索引实现附近的人、地点等功能
    4、物联网场景,使用 MongoDB 存储所有接入的智能设备信息,以及设备汇报的日志信息 ,并对这些信息进行多维度的分析
    5、视频直播,使用 MongoDB 存储用户信息、礼物信息等
  以上及为本部分内容,都是些概念性的问题,了解就好。后续计划2周左右更新一篇。

 

你可能感兴趣的:(mongodb初识)