NoSQL——期末复习(3)第三章MongoDB重点思考题

描述MongoDB数据库的主要特点。

(1)高可伸缩性:MongoDB 采用了分片技术,可以将数据分散在多台服务器上,从而实现水平扩展。

(2)高性能:查询速度快,部分原因是它将数据存储在内存中,还因为采用了多线程和异步 IO 技术,对大量并发请求也能有出色的响应能力。

(3)灵活的数据类型:采用文档型数据模型,通过嵌套文档和数组,可以灵活的表示数据。

(4)JSON 编码:使用 BSON 格式类存储数据,BSON 上文已经提到,是 JSON 的二进制编码,具有更高的查询速度以及更少的存储空间。MongoDB 支持直接读写 JSON 格式的数据,提供了 JSON 风格的查询语言。

(5)可扩展性:存储引擎是可插拔式的,可以根据存储需求选择合适的存储引擎。

(6)自动分片:大型应用所需数据量庞大,MongoDB 可以自动分片,自动分配数据至不同服务器。

(7)数据备份与恢复:快照和复制技术实现数据备份和恢复。

1.MongoDB集群的数据多副本策略?

MongoDB支持分片的多副本,多副本采用主从备份形式。MongoDB称这种机制为复制集机制。

主节点(Primary节点)负责数据的写入和更新。主节点在更新数据的同时,会将操作信息写入日志,称为oplog。

从节点(Secondary节点)监听主节点oplog的变化,并根据其内容维护自身的数据更新,使之和主节点保持一致(最终一致性)。

主节点失联后,从节点会进行选举,将一个从节点提升为主节点。

2.描述MongoDB的分片机制,它支持哪几种分片策略?

MongoDB将数据水平切分机制称为分片(Sharding)。MongoDB支持对文档的自动分片,分片的依据是片键(Shard Keys),分片键可以由文档的一个或多个字段构成,分片使得集群中的数据可以在分布式环境下均衡存储和使用。

MongoDB支持基本的分片策略,即范围分片(MongoDB的默认分片策略。它根据分片键的值范围将数据分布到不同的分片上)和哈希分片(通过对分片键进行哈希运算,将数据均匀分布到各个分片上)。

3.描述MongoDB的集群架构(包含的角色和每个角色的作用)。

当数据分片后,集群中会包含mongod(或称为Shard)、mongos和config三种类型的节点。

mongod负责存储数据,支持为每个shard构建副本集。

Config节点,负责持久化存储分片集群的元数据和配置信息。 支持为Config节点构建副本集。

Mongos节点,一方面作为用户访问集群的入口,负责与客户端的交互;另一方面也承担分片的管理功能。 Mongos支持部署多个进行负载均衡。

相关推荐
ZFSS4 小时前
Localization Translate API 集成与使用指南
java·服务器·数据库·人工智能·mysql·ai编程
东风破1375 小时前
达梦DMDRS搭建、以及DMDRS双向同步
数据库·oracle·dm达梦数据库
KaMeidebaby6 小时前
卡梅德生物技术快报|抗独特型抗体开发:半抗原检测技术瓶颈拆解,抗独特型抗体开发工程化实践
前端·数据库·人工智能·其他·百度·新浪微博
NiceCloud喜云6 小时前
Claude Files API 深入:从上传、复用到配额管理的工程化指南
android·java·数据库·人工智能·python·json·飞书
A XMan.7 小时前
域名Whois信息查询V2版API接入指南
数据库
heimeiyingwang7 小时前
【架构实战】可观测性体系:从监控到全链路追踪
网络·数据库·架构
网管NO.17 小时前
SQL 日期函数全套精讲!时间格式化、日期加减、年月日提取,做日报周报直接套用
数据库·sql
杨云龙UP7 小时前
Linux 根分区被日志吃满?一次 58G Broker 日志清理实战_2026-05-20
linux·运维·服务器·数据库·hdfs·apache
sdk大全7 小时前
Studio 3T for MongoDB 2025.13.0
数据库·mongodb
码农阿豪7 小时前
平替MongoDB:金仓多模数据库助力电子证照国产化实践
数据库·mongodb