zoukankan      html  css  js  c++  java
  • 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周左右更新一篇。

  • 相关阅读:
    VB连接ORACAL过程
    【EXCEL】字段是否存在的查询
    ASP.NET中插入FLASH[学来得]
    做一个健康的的程序员
    SQL语法规范——Insert语句
    WEBBENCH测试网站的负载工具
    常用简易JavaScript函数(转)
    WEB服务器性能/压力测试工具HTTP_LOAD、WEBBENCH、AB、SIEGE使用教程
    Linux服务器监控SHELL脚本(自动发邮件)(转)
    空间页面CSS说明
  • 原文地址:https://www.cnblogs.com/nevermorewang/p/11442482.html
Copyright © 2011-2022 走看看