不能自动切换角色,必须人为指定; - 用户只能写 Master 节点,Slave 节点只能从 Master 拉数据; - 还有一个关键点:Slave 节点只和 Master 通信,Slave 之间相互不感知,这种好处对于 Master 来说优点是非常轻量,缺点是:系统明显存在单点,那么多 Slave 只能从 Master 拉数据,而无法提供自己的判断;MongoDB 3.6 起已不推荐使用主从模式,自 MongoDB 3.2 起,分片群集组件已弃用主从复制。因为 Master-Slave 其中 Master 宕机后不能自...
# 问题描述在使用文档数据库 MongoDB 的时发现 CPU使用率很高,从业务角度来看,发现数据读写处理缓慢,我该如何排查此类问题?# 问题分析通常来说,导致 MongoDB CPU 使用率高有如下几点原因:* 查询语句不够优化,没有合理的索引。* 请求并发量大,当前业务负载和实例类型不匹配,即超出当前服务能力。* 有过重的计算任务。# 解决方案### 1. 查看当前正在运行的语句与 MySQL 中 `show full processlist` 语句功能类似,在 Mon...
# 目的对集合中的数据和索引进行碎片整理。释放磁盘空间,降低磁盘利用率。# 操作流程1. 连接到 Hidden 节点,执行 compact。2. 连接到 Secondary 节点,执行 compact。3. 待前两步做完之后,进行主备切换。4. 对当前的 Primary 执行 compact 命令。# Compact 命令影响&建议1. 回收磁盘碎片前,建议对数据库数据进行备份2. MongoDB 4.4 及之前的版本执行 compact 命令会导致集合所属的数据库被锁定,且该数据库的读写操作将...
# **场景介绍**在使用 MongoDB 过程中,我们建议您对磁盘空间设置监控告警, 避免磁盘空间告急造成业务受损。本文介绍 MongoDB 释放磁盘空间的方法。# **操作步骤**1. 检查您的实例中是否存在已经废弃的索引、集合或者数据库,然后使用 dropIndexes,drop,dropDatabase 命令删除对应的索引、集合或者数据,该类命令执行后,文件会立即删除,磁盘空间会立即归还给操作系统,从而达到释放磁盘空间的目的。2. 从业务的角度来判断是否存...
您可以通过 reshardCollection 命令来修改分片键,实现数据的重新分配。修改分片键的具体操作步骤,请参见 Reshard a Collection。 从 MongoDB 4.4 起,允许分片集合中文档的分片键缺失。更多详情,请参见 Set Missing Shard Key Fields。 设置 shard key 时的注意事项 所有需要分片的集合都必须保证分片键上存在索引,该索引可以是分片键本身的索引,也可以是复合索引。因此在设置分片键时,需注意如下几点:如果需要为已有集合(即集合...
本文汇总了文档数据库 MongoDB 版的常见问题。 实例管理文档数据库 MongoDB 版和 MongoDB 有什么关系? 文档数据库 MongoDB 版提供何种实例规格 在同一账号的同一地域下,是否支持设置同名的实例? 最多支持创建多少个... 为什么实例无法通过公网地址连接,或通过公网地址连接后执行的命令会卡住? 为什么有时执行命令时,会出现 unrecognized pipeline stage name 的报错? 为什么有时实例并没有选择最优索引?
问题现象MongoDB 实例的 PlanCache 中存在最高效的查询索引,但在执行查询时并未选择该最优索引,导致扫描行数过多,出现大量慢查询,占用大量 CPU 内存资源,影响数据库性能。 受影响的实例MongoDB 4.0 实例。 原因MongoDB 4.0 版本的已知问题。关于该问题的更多详情,请参见 jira.mongodb.orgn extremely high 'works' value is cached。 解决办法短期解决办法通过 PlanCache.clear() 命令清除实例的查询缓存。关于 PlanCache.clear(...
更多详情,请参见预检查项(MongoDB)。 注意事项若未选中增量同步,数据同步期间请勿在源实例中写入新的数据,以确保数据一致性。 为实时保障数据的一致性,建议选择结构初始化、全量初始化和增量同步。 由于全量初始化会并发执行 INSERT 操作,导致目标库的集合产生碎片,因此全量初始化完成后目标库的集合存储空间会比源库的集合存储空间大。 在数据同步的过程中,若遇到目标库中已存在同主键值或唯一键的情况,DTS 不会保留目标端中...
本文介绍如何登录文档数据库 MongoDB 版的数据交互台。 前提条件已注册火山引擎账号并完成实名认证。详细操作,请参见如何进行账号注册和实名认证。 已创建 MongoDB 实例并设置了实例的 root 账号密码。详细操作,请参见创建实例。 注意事项当您选中授权数据库工作台将服务 IP 添加到对应数据库实例白名单时,数据库工作台 DBW 后台服务宿主机的 IP 地址将被添加至数据库实例的白名单中。该白名单的名称格式:DBW_Sole_***_***_***...
更多详情,请参见预检查项(MongoDB)。 注意事项若未选中增量同步,数据同步期间请勿在源实例中写入新的数据,以确保数据一致性。 为实时保障数据的一致性,建议选择结构初始化、全量初始化和增量同步。 由于全量初始化会并发执行 INSERT 操作,导致目标库的集合产生碎片,因此全量初始化完成后目标库的集合存储空间会比源库的集合存储空间大。 在数据同步的过程中,若遇到目标库中已存在同主键值或唯一键的情况,DTS 不会保留目标端中...
请参见预检查项(MongoDB)。 在数据同步的过程中,若遇到目标库中已存在同主键值或唯一键的情况,DTS 不会保留目标端中冲突的数据,即源端的数据将会覆盖掉目标端的数据。当数据进行冲突覆盖时,如果目标库中存在同名表,可能会导致数据不一致等问题,具体如下所示。建议您通过表名映射的方式、删除或重命名目标库中同名表的方式避免数据不一致等问题降低业务风险。 表结构一致时:同步的数据将覆盖目标表中与源库主键或唯一键的值相同的...
更多详情,请参见预检查项(MongoDB)。 注意事项若未选中增量同步,数据同步期间请勿在源实例中写入新的数据,以确保数据一致性。 为实时保障数据的一致性,建议选择结构初始化、全量初始化和增量同步。 由于全量初始化会并发执行 INSERT 操作,导致目标库的集合产生碎片,因此全量初始化完成后目标库的集合存储空间会比源库的集合存储空间大。 在数据同步的过程中,若遇到目标库中已存在同主键值或唯一键的情况,DTS 不会保留目标端中...
更多详情,请参见预检查项(MongoDB)。 注意事项若未选中增量同步,数据同步期间请勿在源实例中写入新的数据,以确保数据一致性。 为实时保障数据的一致性,建议选择结构初始化、全量初始化和增量同步。 由于全量初始化会并发执行 INSERT 操作,导致目标库的集合产生碎片,因此全量初始化完成后目标库的集合存储空间会比源库的集合存储空间大。 在数据同步的过程中,若遇到目标库中已存在同主键值或唯一键的情况,DTS 不会保留目标端中...