MongoDB 4.0 支持事务为了更好地替代MySQL,MongoDB引入了事务技术,事务在很多其它非关系型数据库中都是很难实现的功能,但通过MongoDB 4.0发布,我们可以实现数据库事务,比如增删改查、创建新的集合,以及删除、修改和更新集合的文档,而不会危及数据的完整性。MongoDB 拥有比MySQL更快的性能MongoDB更快的性能是另一个使它能够替代MySQL的原因。MySQL使用类似的查询语句来处理数据,这些查询语句非常容易受到索引大小、数据量和...
# **场景介绍**在 MongoDB 中,对单个文档执行的操作是原子操作。 多文档事务使应用程序可以跨多个文档执行原子操作。 从 MongoDB 4.0 版本开始支持基于副本集的多文档事务,从 4.2 版本开始,提供了跨分片的分布式事务多文档事务遵循 ACID 语义:* 原子性:一组操作只会全部成功,或者全部失败* 一致性:保证数据库整体数据的完整性和业务数据的一致性* 隔离性:事务之间不会相互影响* 持久性:事务一旦成功提交,将会进行持久化...
# **场景介绍**在使用 MongoDB 过程中,我们建议您对磁盘空间设置监控告警, 避免磁盘空间告急造成业务受损。本文介绍 MongoDB 释放磁盘空间的方法。# **操作步骤**1. 检查您的实例中是否存在已经废弃的索引、集合或者数据库,然后使用 dropIndexes,drop,dropDatabase 命令删除对应的索引、集合或者数据,该类命令执行后,文件会立即删除,磁盘空间会立即归还给操作系统,从而达到释放磁盘空间的目的。2. 从业务的角度来判断是否存...
# 目的对集合中的数据和索引进行碎片整理。释放磁盘空间,降低磁盘利用率。# 操作流程1. 连接到 Hidden 节点,执行 compact。2. 连接到 Secondary 节点,执行 compact。3. 待前两步做完之后,进行主备切换。4. 对当前的 Primary 执行 compact 命令。# Compact 命令影响&建议1. 回收磁盘碎片前,建议对数据库数据进行备份2. MongoDB 4.4 及之前的版本执行 compact 命令会导致集合所属的数据库被锁定,且该数据库的读写操作将...
在使用文档数据库 MongoDB 版的过程中,若存在查询语句不够优化(如未设置合理索引)、请求并发量大、计算任务过重等情况时,可能会使数实例 CPU 使用率变高,从而导致数据读写变慢、超时增加等问题,甚至严重影响业务的正常运行。本文从查询语句、慢日志、执行计划等方面,介绍如何排查并定位 MongoDB 实例 CPU 使用率高的问题。 查看正在运行的语句您可以参考如下步骤查看数据库中正在运行的语句: 通过 Mongo Shell 工具连接实例。具体...
文档数据库 MongoDB 版支持自定义参数值,本文介绍 MongoDB 实例中支持的参数相关信息。 说明 关于表格中的标识,说明如下: ✔️ :表示当前实例或组件类型支持该参数。 ❌ :表示当前实例或组件类型不支持该参数。 参... 表示限制索引键的长度。即当 MongoDB 创建索引时,如果索引键的长度超出了 MongoDB 所支持的最大限制(即 1024 Byte),MongoDB 就会返回一个错误并拒绝创建该索引。 false:表示不限制索引键的长度。则当索引键的值超...
本文介绍如何登录文档数据库 MongoDB 版的数据交互台。 前提条件已注册火山引擎账号并完成实名认证。详细操作,请参见如何进行账号注册和实名认证。 已创建 MongoDB 实例并设置了实例的 root 账号密码。详细操作,请... MongoDB 版。 实例名称 从下拉列表中选择目标实例。 节点 ID 从下拉列表中选择目标节点 ID。 说明 在登录的实例类型为副本集,且选择的节点 ID 为 Secondary 时,仅支持查看该节点下的数据库、集合和索引,不支持增删...
本文汇总了文档数据库 MongoDB 版的常见问题。 实例管理文档数据库 MongoDB 版和 MongoDB 有什么关系? 文档数据库 MongoDB 版提供何种实例规格 在同一账号的同一地域下,是否支持设置同名的实例? 最多支持创建多少个... 文档数据库 MongoDB 版是否支持 SRV 的连接方式? 功能特性文档数据库 MongoDB 版是否支持多文档事务功能? 文档数据库 MongoDB 版是否支持嵌套文档? 文档数据库 MongoDB 版如何处理节点故障? 实例磁盘使用率超过多...
# **场景介绍**在使用 MongoDB 过程中,我们建议您对磁盘空间设置监控告警, 避免磁盘空间告急造成业务受损。本文介绍 MongoDB 释放磁盘空间的方法。# **操作步骤**1. 检查您的实例中是否存在已经废弃的索引、集合或者数据库,然后使用 dropIndexes,drop,dropDatabase 命令删除对应的索引、集合或者数据,该类命令执行后,文件会立即删除,磁盘空间会立即归还给操作系统,从而达到释放磁盘空间的目的。2. 从业务的角度来判断是否存...
# 目的对集合中的数据和索引进行碎片整理。释放磁盘空间,降低磁盘利用率。# 操作流程1. 连接到 Hidden 节点,执行 compact。2. 连接到 Secondary 节点,执行 compact。3. 待前两步做完之后,进行主备切换。4. 对当前的 Primary 执行 compact 命令。# Compact 命令影响&建议1. 回收磁盘碎片前,建议对数据库数据进行备份2. MongoDB 4.4 及之前的版本执行 compact 命令会导致集合所属的数据库被锁定,且该数据库的读写操作将...
问题现象MongoDB 实例的 PlanCache 中存在最高效的查询索引,但在执行查询时并未选择该最优索引,导致扫描行数过多,出现大量慢查询,占用大量 CPU 内存资源,影响数据库性能。 受影响的实例MongoDB 4.0 实例。 原因MongoDB 4.0 版本的已知问题。关于该问题的更多详情,请参见 jira.mongodb.orgn extremely high 'works' value is cached。 解决办法短期解决办法通过 PlanCache.clear() 命令清除实例的查询缓存。关于 PlanCache.clear(...
文档数据库 MongoDB 版支持分片集群实例架构,能够提供可横向扩展的 MongoDB 服务。分片集群通过将大型集合自动分割到不同节点,来满足大规模高性能场景下的容量和性能需求。本文介绍使用 MongoDB 分片集群的相关建议... 该索引可以是分片键本身的索引,也可以是复合索引。因此在设置分片键时,需注意如下几点:如果需要为已有集合(即集合中已存在数据)设置分片键,则必须先为分片键创建索引,再通过 sh.shardCollection() 命令进行分片。创...
# 问题描述在使用文档数据库 MongoDB 的时发现 CPU使用率很高,从业务角度来看,发现数据读写处理缓慢,我该如何排查此类问题?# 问题分析通常来说,导致 MongoDB CPU 使用率高有如下几点原因:* 查询语句不够优化,没有合理的索引。* 请求并发量大,当前业务负载和实例类型不匹配,即超出当前服务能力。* 有过重的计算任务。# 解决方案### 1. 查看当前正在运行的语句与 MySQL 中 `show full processlist` 语句功能类似,在 Mon...