- MongoDB官方文档中文版
- MongoDB中文手册说明
- MongoDB简介
- 安装 MongoDB
- The mongo Shell
- MongoDB CRUD 操作
- 聚合
- 数据模型
- 事务
- 索引
- 安全
- 安全检查列表
- 启用访问控制
- 身份验证
- 基于角色的访问控制
- TLS / SSL(传输加密)
- 静态加密
- 客户端字段级加密
- 审计
- 网络和配置强化
- 实现字段级别修订
- 安全参考
- 附录
- 变更流
- 复制
- 分片
- 分片键
- 哈希分片
- 范围分片
- 区
- 管理分片区
- 按位置细分数据
- 用于更改SLA或SLO的分层硬件
- 按应用或客户细分数据
- 仅插入工作负载的分布式本地写入
- 管理分片区
- 使用块进行数据分区
- 在分片集群中拆分数据块
- 管理
- 存储
- 存储引擎
- 日志记录
- 管理日志记录
- GridFS
- FAQ:MongoDB 存储
- 存储引擎
- 参考
- 运算符
- 查询与映射运算符
- 更新运算符
- 聚合管道阶段
- 聚合管道操作符
- $abs (aggregation)
- $acos (aggregation)
- $acosh (aggregation)
- $add (aggregation)
- $addToSet (aggregation)
- $allElementsTrue (aggregation)
- $and (aggregation)
- $anyElementTrue (aggregation)
- $arrayElemAt (aggregation)
- $arrayToObject (aggregation)
- $asin (aggregation)
- $asinh (aggregation)
- $atan (aggregation)
- $atan2 (aggregation)
- $atanh (aggregation)
- $avg (aggregation)
- $ceil (aggregation)
- $cmp (aggregation)
- $concat (aggregation)
- $concatArrays (aggregation)
- $cond (aggregation)
- $convert (aggregation)
- $cos (aggregation)
- $dateFromParts (aggregation)
- $dateToParts (aggregation)
- $dateFromString (aggregation)
- $literal (aggregation)
- 查询修饰符
- 数据库命令
- 聚合命令
- 地理空间命令
- 查询和写操作命令
- 查询计划缓存命令
- 认证命令
- 用户管理命令
- 角色管理命令
- 复制命令
- 分片命令
- 会话命令
- 管理命令
- 诊断命令
- 免费监控命令
- 系统事件审计命令
- mongo Shell 方法
- 集合方法
- db.collection.aggregate()
- db.collection.bulkWrite()
- db.collection.copyTo()
- db.collection.count()
- db.collection.countDocuments()
- db.collection.estimatedDocumentCount()
- db.collection.createIndex()
- db.collection.createIndexes()
- db.collection.dataSize()
- db.collection.deleteOne()
- db.collection.deleteMany()
- db.collection.distinct()
- db.collection.drop()
- db.collection.dropIndex()
- db.collection.dropIndexes()
- db.collection.ensureIndex()
- db.collection.explain()
- db.collection.find()
- db.collection.findAndModify()
- db.collection.findOne()
- db.collection.findOneAndDelete()
- db.collection.findOneAndReplace()
- db.collection.findOneAndUpdate()
- db.collection.getIndexes()
- db.collection.getShardDistribution()
- db.collection.getShardVersion()
- db.collection.insert()
- db.collection.insertOne()
- db.collection.insertMany()
- db.collection.isCapped()
- db.collection.latencyStats()
- db.collection.mapReduce()
- db.collection.reIndex()
- db.collection.remove()
- db.collection.renameCollection()
- db.collection.replaceOne()
- db.collection.save()
- db.collection.stats()
- db.collection.storageSize()
- db.collection.totalIndexSize()
- db.collection.totalSize()
- db.collection.update()
- db.collection.updateOne()
- db.collection.updateMany()
- db.collection.watch()
- db.collection.validate()
- 词汇表
- 默认的MongoDB端口
- 默认的MongoDB读/写关注
- 服务器会话
- MongoDB驱动
- FAQ
- 联系我们
- 更多资料
- [快学Mongo]
- [Mongo问题讨论区]
- [Mongo 驱动使用手册]
- 本书使用 GitBook 发布
操作检查列表
操作检查表
下面的清单和开发清单列表一同提供了一些建议,帮助您避免生产环境下MongoDB部署中的问题。
文件系统
将磁盘分区与RAID配置对齐。
避免对 dbPath 使用 NFS 驱动器。使用 NFS 驱动器可能导致性能下降和不稳定。
有关详细信息,请参阅:远程文件系统 。
VMware 用户应该通过 NFS 使用 VMware 虚拟驱动器。
- Linux/Unix:将驱动器格式化为 XFS 或 EXT4。如果可能的话,使用 XFS,因为它通常在MongoDB 中运行得更好。
对于 WiredTiger 存储引擎,强烈建议使用XFS,以避免在将 EXT4 与 WiredTiger 一起使用时产生性能问题。
- 如果使用 RAID,可能需要使用 RAID 几何阵列配置 XFS。
- Windows:使用 NTFS 文件系统。不要使用任何 FAT 文件系统(例如 FAT 16/32/exFAT)。
复制
验证所有非隐藏副本集成员在 RAM,CPU,磁盘,网络设置等方面的配置是否相同。
配置 oplog 的大小 以适合您的使用案例:
复制 oplog 窗口包括正常维护和停机时间窗口,以避免需要完全重新同步。
复制 oplog 窗口应涵盖从上次备份还原副本集成员所需的时间。
在 3.4 版本中更改:复制 oplog 窗口不再需要覆盖通过初始同步还原副本集成员所需的时间,因为在数据复制期间会提取 oplog 记录。但是,正在还原的成员必须在本地数据库中具有足够的磁盘空间,以便在此数据复制阶段的持续时间内临时存储这些 oplog 记录。
对于早期版本的 MongoDB,复制 oplog 窗口应涵盖通过初始同步还原副本集成员所需的时间。
确保您的副本集至少包含三个数据承载节点,这些节点与日志记录一起运行,并且为了可用性和持久性,您使用 w:"majority" 写策略发出写操作。
配置副本集成员时使用主机名,而不是IP地址。
确保所有 mongod 实例之间的完全双向网络连接。
- 确保每个主机都可以自行解决。
- 确保副本集包含奇数个投票成员。
- 确保 mongod 实例有0票或1票。
- 对高可用性,将副本集部署到至少三个数据中心。
分片
- 将 配置服务器放在专用硬件上,以便在大型集群中获得最佳性能。确保硬件有足够的 RAM 将数据文件完全保存在内存中,并且有专用的存储器。
- 根据生产配置指南部署 mongos 前端路由。
- 使用NTP来同步切分集群所有组件上的时钟。
- 确保 mongod, mongos 和配置服务器之间的完全双向网络连接。
- 使用 CNAMEs 将配置服务器标识到集群,以便可以在不停机的情况下重命名和重新编号配置服务器。
日志:WiredTiger存储引擎
- 确保所有实例都使用日志。
- 将日志放在其自己的低延迟磁盘上,以适应写密集型的工作负载。请注意,这将影响快照样式备份,因为构成数据库状态的文件将位于单独的卷上。
硬件
- 使用 RAID10 和 SSD 驱动器可获得最佳性能。
- SAN 和虚拟化:
部署到云硬件
- Windows Azure:将 TCP 长连接(TCP长连接时间)调整为100-120。Azure 负载均衡器上的 TCP 空闲超时对于 MongoDB 的连接池行为太慢。有关详细信息,请参阅 Azure产品说明。
- 在具有高延迟存储的系统(如Microsoft Azure)上使用 MongoDB 版本 2.6.4 或更高版本,因为这些版本包括这些系统性能的改进。
操作系统配置
Linux
关闭透明大页。有关更多信息,请参见透明大页设置。
在存储数据库文件的设备上调整文件预读设置 。
- 对于 WiredTiger 存储引擎,无论存储介质类型(旋转磁盘、固态硬盘等)如何,请将文件预读设置在8到32之间,除非测试显示在较高的文件预读值中有可测量、可重复和可靠的好处。
MongoDB专业支持 可以提供关于交替文件预读配置的建议和指导。
如果在 RHEL/CentOS 上使用 tuned(动态内核调优工具),则必须自定义您的 tuned 配置文件。RHEL/CentOS 附带的许多 tuned 文件可能会对其默认设置的性能产生负面影响。将您选择的 tuned 文件自定义为:
- 禁用透明大页。有关说明,请参见使用 tuned 和 ktune。
- 无论存储介质类型如何,都将文件预读设置为8到32之间。有关详细信息,请参阅预读设置。
对SSD驱动器使用 noop 或 deadline 磁盘调度程序。
对来宾虚拟机中的虚拟化驱动器使用 noop 磁盘调度程序。
禁用 NUMA 或将 vm.zone_reclaim_mode 设置为0并运行具有节点交错的 mongod 实例。请参阅:MongoDB和NUMA硬件了解更多信息。
调整硬件上的 ulimit 值以适合您的用例。如果多个 mongod 或者 mongos 实例在同一用户下运行,请相应地缩放 ulimit 值。有关详细信息,请参见:UNIX ulimit 设置。
使用noatime作为 dbPath 挂载点。
为部署配置足够的文件句柄(fs.file max)、内核 pid 限制(kernel.pid_max)、每个进程的最大线程数(kernel.threads max)和每个进程的最大内存映射区域数(vm.max_map_count)。对于大型系统,以下值提供了一个良好的起点:
- fs.file-max 值为98000,
- kernel.pid_max 值为64000,
- kernel.threads-max 值为64000, 和
- vm.max_map_count 值为128000
确保系统已配置交换空间。有关适当大小的详细信息,请参阅操作系统的文档。
确保系统默认的 TCP 长连接设置正确。TCP 长连接时间值300通常为副本集和分片集群提供更好的性能。有关详细信息,请参阅常见问题中的 TCP 保持时间是否影响MongoDB部署? 。
Window
- 考虑禁用 NTFS “最后访问时间”更新。这类似于在 Unix-like 系统上禁用atime。
- 使用默认分配单元大小的4096 字节格式化NTFS磁盘。
备份
- 安排定期测试备份和恢复过程,以便手头有时间估计,并验证其功能。
监控
使用 MongoDB Cloud Manager或者MongoDB 企业高级版中提供的本地解决方案- Ops Manager 或者另一个监控系统来监控关键数据库指标并为它们设置警报。包括以下指标的警报:
- 复制滞后
- 复制 oplog 窗口
- 断言
- 队列
- 页面错误
- 监视服务器的硬件统计信息。尤其要注意磁盘使用、CPU 和可用磁盘空间。
在没有磁盘空间监视的情况下,以下方案作为预防措施:
- 在storage.dbPath驱动器上创建一个4 GB的虚拟文件,以确保磁盘满时有可用空间。
- 如果没有其他监视工具可用,cron+df 的组合可以在磁盘空间达到高水位时发出警报。
负载均衡
- 将负载平衡器配置为启用“粘滞会话”或“客户端亲和性”,并为现有连接提供足够的延时。
- 避免在 MongoDB 集群或副本集组件之间放置负载平衡器。
原文链接:https://docs.mongodb.com/manual/administration/production-checklist-operations/
译者:孔令升
Copyright © 上海锦木信息技术有限公司 all right reserved,由 MongoDB汉化小组 提供技术支持文件修订时间: 2020-10-11 20:53:05