# 目的对集合中的数据和索引进行碎片整理。释放磁盘空间,降低磁盘利用率。# 操作流程1. 连接到 Hidden 节点,执行 compact。2. 连接到 Secondary 节点,执行 compact。3. 待前两步做完之后,进行主备切换。4. 对当前的 Primary 执行 compact 命令。# Compact 命令影响&建议1. 回收磁盘碎片前,建议对数据库数据进行备份2. MongoDB 4.4 及之前的版本执行 compact 命令会导致集合所属的数据库被锁定,且该数据库的读写操作将...
MongoDB在版本4.0中引入了革命性的事务支持,使其成为在一个存储器中支持数据的可伸缩NoSQL数据库。今天,具有事务的MongoDB的受欢迎程度越来越高,这使得许多公司开始思考使用MongoDB来代替MySQL。为什么MongoDB取代MySQL?MongoDB 与MySQL存在很多不同之处, MySql 专为关系型数据库而设计,而MongoDB提供了一种更灵活的数据模型,可以反映客户需求。此外,MongoDB也支持多个数据中心灵活部署,这在MySQL中是不可能实现的。由于Mong...
# **场景介绍**在使用 MongoDB 过程中,我们建议您对磁盘空间设置监控告警, 避免磁盘空间告急造成业务受损。本文介绍 MongoDB 释放磁盘空间的方法。# **操作步骤**1. 检查您的实例中是否存在已经废弃的索引、集合或者数据库,然后使用 dropIndexes,drop,dropDatabase 命令删除对应的索引、集合或者数据,该类命令执行后,文件会立即删除,磁盘空间会立即归还给操作系统,从而达到释放磁盘空间的目的。2. 从业务的角度来判断是否存...
# 问题描述在使用文档数据库 MongoDB 的时发现 CPU使用率很高,从业务角度来看,发现数据读写处理缓慢,我该如何排查此类问题?# 问题分析通常来说,导致 MongoDB CPU 使用率高有如下几点原因:* 查询语句不够优化,没有合理的索引。* 请求并发量大,当前业务负载和实例类型不匹配,即超出当前服务能力。* 有过重的计算任务。# 解决方案### 1. 查看当前正在运行的语句与 MySQL 中 `show full processlist` 语句功能类似,在 Mon...
问题现象MongoDB 实例的 PlanCache 中存在最高效的查询索引,但在执行查询时并未选择该最优索引,导致扫描行数过多,出现大量慢查询,占用大量 CPU 内存资源,影响数据库性能。 受影响的实例MongoDB 4.0 实例。 原因MongoDB 4.0 版本的已知问题。关于该问题的更多详情,请参见 jira.mongodb.orgn extremely high 'works' value is cached。 解决办法短期解决办法通过 PlanCache.clear() 命令清除实例的查询缓存。关于 PlanCache.clear(...
MongoDB在版本4.0中引入了革命性的事务支持,使其成为在一个存储器中支持数据的可伸缩NoSQL数据库。今天,具有事务的MongoDB的受欢迎程度越来越高,这使得许多公司开始思考使用MongoDB来代替MySQL。为什么MongoDB取代MySQL?MongoDB 与MySQL存在很多不同之处, MySql 专为关系型数据库而设计,而MongoDB提供了一种更灵活的数据模型,可以反映客户需求。此外,MongoDB也支持多个数据中心灵活部署,这在MySQL中是不可能实现的。由于Mong...
背景信息文档数据库 MongoDB 版实例在删除数据时,不会直接回收被删除数据的磁盘空间(这些空间会被标记为空闲),后续新写入的数据不会占用新的磁盘空间,而是重用之前空闲的磁盘空间,那些未被使用的空闲存储空间则被称作磁盘碎片。随着删除的操作增多,碎片也会越来越多,磁盘碎片越多表明磁盘利用率越低。Compact 命令可用于重写和整理 MongoDB 集合中所有的数据和索引,通过回收数据删除后所产生的磁盘碎片来提升磁盘利用率。关于 c...
MongoDB Go SDK 支持通过 Session 的方式来初始化客户端。通过 Session 方式创建的 MongoDB 客户端,底层会实现 HTTP/HTTPS 资源(连接或请求)的复用。当需要初始化多个客户端进行操作时,通过 Session 方式创建可以提升客户端的性能。本文介绍如何通过 Session 的方式来初始化客户端。 前提条件已下载并安装 MongoDB Go SDK。具体操作步骤,请参见下载安装 SDK。 初始化客户端之前,需确保已获取如下信息:账号的 Access Key ID(简称 ...
实现数据的重新分配。修改分片键的具体操作步骤,请参见 Reshard a Collection。 从 MongoDB 4.4 起,允许分片集合中文档的分片键缺失。更多详情,请参见 Set Missing Shard Key Fields。 设置 shard key 时的注意事项 所有需要分片的集合都必须保证分片键上存在索引,该索引可以是分片键本身的索引,也可以是复合索引。因此在设置分片键时,需注意如下几点:如果需要为已有集合(即集合中已存在数据)设置分片键,则必须先为分片键创建索...
本文汇总了文档数据库 MongoDB 版的常见问题。 实例管理文档数据库 MongoDB 版和 MongoDB 有什么关系? 文档数据库 MongoDB 版提供何种实例规格 在同一账号的同一地域下,是否支持设置同名的实例? 最多支持创建多少个文档数据库 MongoDB 版实例? 文档数据库 MongoDB 版是否支持添加或减少节点或分片? 文档数据库 MongoDB 版支持哪些数据库版本? 如何查看 MongoDB 实例使用的数据库版本? 如何将 MongoDB 4.0 版本升级到 MongoDB 5.0...
# **场景介绍**在使用 MongoDB 过程中,我们建议您对磁盘空间设置监控告警, 避免磁盘空间告急造成业务受损。本文介绍 MongoDB 释放磁盘空间的方法。# **操作步骤**1. 检查您的实例中是否存在已经废弃的索引、集合或者数据库,然后使用 dropIndexes,drop,dropDatabase 命令删除对应的索引、集合或者数据,该类命令执行后,文件会立即删除,磁盘空间会立即归还给操作系统,从而达到释放磁盘空间的目的。2. 从业务的角度来判断是否存...
# 问题描述在使用文档数据库 MongoDB 的时发现 CPU使用率很高,从业务角度来看,发现数据读写处理缓慢,我该如何排查此类问题?# 问题分析通常来说,导致 MongoDB CPU 使用率高有如下几点原因:* 查询语句不够优化,没有合理的索引。* 请求并发量大,当前业务负载和实例类型不匹配,即超出当前服务能力。* 有过重的计算任务。# 解决方案### 1. 查看当前正在运行的语句与 MySQL 中 `show full processlist` 语句功能类似,在 Mon...
本文介绍如何登录文档数据库 MongoDB 版的数据交互台。 前提条件已注册火山引擎账号并完成实名认证。详细操作,请参见如何进行账号注册和实名认证。 已创建 MongoDB 实例并设置了实例的 root 账号密码。详细操作,请... MongoDB 版。 实例名称 从下拉列表中选择目标实例。 节点 ID 从下拉列表中选择目标节点 ID。 说明 在登录的实例类型为副本集,且选择的节点 ID 为 Secondary 时,仅支持查看该节点下的数据库、集合和索引,不支持增删...