NoSQL—mongodb常见使用和入门

NoSQL介绍:

NoSQL数据管理系统是目前非常流行的一种非关系性、分布式、不支持ACID设计规范式的数据库;NoSQL简单的数据模型、元数据和数据分离、弱一致性、高吞吐量、高水平扩展能力和低端硬件集群使其流行的主要原因,而mongodb就是NoSQL数据库一种非常流行的实现方式。

 

常见的NoSQL数据存储模型
列式模型 文档类型

应用场景:在分布式文件系统之上提供支持随机读写分离的分布式数据库

典型产品:HBase、Hypertable、Cassandra
数据模型:以“列”为中心进行存储,将相同的列存储在一起
优点:快速查询、高可扩展性、易于实现分布式扩展

应用场景:非强事务的web应用
典型产品:MongoDB、Elasticsearch、CouchDB
数据模型:键值模型,以文档存储
优点:数据模型无须事先定义
键值模型 图式模型
应用场景:
内容缓存,用于大量并发数据访问的高负载场景
典型产品:DynamoDB、Redis、Riak
数据模型:基于hash表实现的key-value
优点:查询速度快
应用场景:社交网络、推荐系统、关系图谱
典型产品:Neo4j、Infinite Graph、TITAN
数据模型:图式结构
优点:适用于图式场景计算

 

MongoDB的复制功能有两种类型:

第一种类型:master/slave模型,这类模型与MySQL模型基本相同

第二种模型:replica set复制集、副本集;服务于同一数据集的多个mongodb实例;与mysql的主从类似,但是要比mysql主从工作效率要高

特性:(1)至少三个节点,至少为奇数个节点

(2)当节点数不足时,使用arbiter(仲裁者)来参与

(3)heartbeat每2s中的信息监测以及自动失效转移

MongoDB复制集中特殊节点的类型:

(1)0优先级的节点:冷备节点,不会被选举成为主节点,但可以参与选举

(2)被隐藏的节点:首先是一个0优先级的从节点,且对客户端不可见

(3)延迟复制的节点:首先是一个0优先级的从节点,且复制时间落后于主节点一个固定时长

(4)arbiter:仲裁者,没有数据,只负责仲裁

MongoDB的复制架构:
(1)oplog:
是存储在local数据库中,最小为1G,大小为固定的文件;同时又只有主节点才可以有写入操作,而从节点不会有写入操作;而local数据存放了数据集的所有元数据和oplog,用于存储oplog的是一个名为oplog.rs的collection,oplog.rs的大小依赖于OS和文件系统;但其大小可以自定义(oplogSize)

(2)heartbeat: 用于监测各个节点复制时的信息

 

MongoDB复制过程:

(1)初时同步:initial sync

首先克隆所有数据库

其次应用数据集的所有改变;复制oplog并应用于本地

最后为所有collection构建索引

(2)回滚后追赶:post-rollback catch-up

(3)切分块迁移: sharding chunk mingratings

 

MongoDB的索引类型:

单字段索引、组合索引(多字段索引)、多键索引、空间索引、文本索引、hash索引

 

以上是本人对学习mongodb的一些总结,只总结了一些基础知识,常用命令没有总结。大家有什么好的建议多给提一下。O(∩_∩)O

原创文章,作者:马行空,如若转载,请注明出处:http://www.178linux.com/7727

(1)
马行空马行空
上一篇 2015-08-31 10:43
下一篇 2015-09-01 23:12

相关推荐

  • LAMP基于RPM包实现(httpd与php以fastcgi方式结合) 2

    概述:     承接上篇,本篇为介绍下利用rpm包,实现LAMP组合,其中httpd和php的结合方式为fastcgi,也就是php运行为独立的服务,监听的某个套接字上,接受请求,提供服务     包括LAMP安装过程(http、php-fpm、mysql-server、php-…

    Linux干货 2016-10-15
  • 第五周作业

    1、显示当前系统上root、fedora或user1用户的默认shell; [root@localhost ~]# egrep '^(fedora|root|user1):' /etc/passwd |cut -d: -f1,7 root:/bin/bash user1…

    Linux干货 2017-02-04
  • 毕业即高薪只是别人家的好事吗?

    1 毕业即高薪?运气?梦想?还是嘘头?  同学们,你还在担心毕业后不好找工作吗,毕业即高薪只是别人家的好事吗?马哥linux又一名在校生学员毕业即20w+高薪名企,你还在等什么呢? 真的只是梦想么?还是只存在于别人家的公司? 越来越多的在校大学生凭着强烈的上进心踊跃的加入了马哥linux的学习阵营,这名研究生同学在研究生毕业的同时也从马哥linux…

    2015-09-06
  • 程序员的相关笑话(二)

    从前,有一个牧羊人,他有很多的羊。一天他赶着他的那群羊到了一条公路边上。突然,有一辆保时洁急驶过来,上面坐着一个年轻人人,穿着Armani的衣服,和Cerutti的皮鞋,Ray-Ban的太阳眼镜,TAG-Heuer的手表,以前Versace的领带。 他走到牧羊人面前问牧羊人:“如果我能说出你有多少只羊,你能给我一只吗?” 牧羊人看了看他那一大群数都数不过来的…

    Linux干货 2016-07-10
  • 软件包管理(rpm篇)

    软件包管理(rpm篇)静态和动态链接    链接主要作用是把各个模块之间相互引用的部分处理好,使得各个模块之间能够正确地衔接,分为静态链接和动态链接    静态链接        把程序对应的依赖库复制一份到包&nbsp…

    Linux干货 2017-04-24
  • Linux—文本处理(查看,统计,排序,抽取,合并,grep,基本正则表达式)

    Linux的文本管理有着众多的文本命令工具,这些工具基本可以满足不同的文本处理要求,很是灵活,掌握文本管理命令对系统的维护是必备基础技能。 1.文本查看命令:     (1)cat        语法:        cat [OPTION]… […

    Linux干货 2016-08-07