![b1ad35e87754c8fc9f0bcf94b0978e28.png](https://i-blog.csdnimg.cn/blog_migrate/ec993f70332d94175dbe6fb2d6bfc2a0.jpeg)
之前我曾有过一次mongodb的介绍,但那是年少无知,对mongo认识得不够充分,所以当时那篇专题介绍只是介绍了一个大概的轮廓就草草敷衍了事了。对此我做了深刻的反省与自我批评。接下来,今天就mongo的深度探索将在下面的时间里倾情为大家呈现。
MongoDB的基本概念
一、MongoDB基本概念与关系数据的对应关系
![c1e28f0dca26747d6c239e0e23dd1727.png](https://i-blog.csdnimg.cn/blog_migrate/50588e60858a97d9cce15ef8e754d8d2.jpeg)
二、MongoDB的数据层次结构
文档(Documents),集合( Collections), 和数据库( Databases)三层
§文档存储在集合中
§集合存储在数据库中
§例如:
•数据库(Database): products
•集合(Collections): books, movies, music
§数据库和集合的组合,构成MongoDB的命名空间
•products.books
•products.movies
•products.music
*数据库名最长不能超过64个字节,命名空间最长不能超过120字节
三、MongoDB的数据结构
§MongoDB采用JSON文档结构
•JSON的全称:JavaScript Object Notation
•JSON的格式:支持如下数据格式
字符串 :e.g., “Thomas”
数字 :e.g., 29, 3.7)
布尔:true / false
空值:null
数组:e.g., [88.5, 91.3, 67.1]
对象:object
{
"firstname" : "Thomas",
"lastname" : "Smith",
"age" : 29
}
§MongoDB采用BSON格式保存数据
MongoDB使用了BSON这种结构来存储数据和网络数据交换。把这种格式转化成一文档这个概念(Document),因为BSON是schema-free的,所以在MongoDB中所对应的文档也有这个特征,这里的一个Document也可以理解成关系数据库中的一条记录(Record),只是这里的Document的变化更丰富一些,如Document可以嵌套。
MongoDB以BSON做为其存储结构的一种重要原因是其可遍历性。
四、MongoDB的功能定位
![c21ce0b9af405e0cecb6f51980adc988.png](https://i-blog.csdnimg.cn/blog_migrate/09355169036cb1e67cb6cc86b5d4097f.jpeg)
Memcache所指为内存数据库
RDBMS为关系型数据库
五、MongoDB部署模型
![ca12d08b5ba072e57e9e98b29e2a12e7.png](https://i-blog.csdnimg.cn/blog_migrate/70e0ce6cc83f18f3c48bbce372daf6c8.jpeg)
在生产上部署mongodb数据库一般采取分片或主从的模式进行部署
六、MongoDB的备份与恢复
![998210bc5eeb074a4ae3b4be4d3b5f33.png](https://i-blog.csdnimg.cn/blog_migrate/9c3d4d62826d705465f68f494f4af0a0.jpeg)
时刻1
PRIMARY/SECONDRY处于相同的状态,总文档数相同,文档内容也相同,我们称之为状态A
时刻2
PRIMARY节点上插入了一个新文档,进入状态B
时刻3
SECONDARY上复制到新文档,进入状态B
•最终一致性决定了SECONDARY上只会出现PRIMARY上出现过的状态
七、MongoDB的设计原则
•为性能优化,而不是空间
•为最重要场景优化,不求面面俱到
![c3f021f5d3266a0106f62fa1d3075dd5.png](https://i-blog.csdnimg.cn/blog_migrate/5d4d4213af2ceeff0f80134620281073.jpeg)