【赵渝强老师】MongoDB的In-Memory存储引擎

  MongoDB的In-Memory存储引擎将会把数据存储在内存中。除了少量的元数据和诊断日志以外,In-Memory存储引擎不会维护任何存储在硬盘上的数据,从而避免硬盘的读写操作,以减少数据查询的延迟,从而提高性能。

提示:虽然In-Memory存储引擎不会向文件系统写入数据,但是它任然需要使用--dbpath参数指定一个目录用于存储少量的元数据和诊断日志。通过指定参数--inMemorySizeGB可以设置MongoDB占用的内存数量,默认值是:50% of RAM - 1GB。

  视频讲解如下:

MongoDB的In-Memory存储引擎
【赵渝强老师】MongoDB的In-Memory存储引擎

  下面通过一个示例来演示如何使用MongoDB的In-Memory存储引擎。

(1)创建目录用于保存In-Memory存储引擎的元数据和诊断日志。

powershell 复制代码
mkdir -p /data/memory

(2)编辑配置文件/data/memory/memory.conf,输入下面的内容。

powershell 复制代码
dbpath=/data/memory/ 
port=27019
fork=true
logpath=/data/memory/memory.log
storageEngine=inMemory 

(3)启动MongoDB服务器端。

powershell 复制代码
mongod --config /data/memory/memory.conf

(4)使用mongoshell连接MongoDB。

powershell 复制代码
mongo --port 27019

(5)在MongoDB中创建一个数据库和一张新的集合,并插入一条数据。

powershell 复制代码
> use demomemory
> db.test2.insert({name:'Tom',age:18});

(6)执行一个简单的查询。

powershell 复制代码
> db.test2.find()

输出的信息如下:
{ "_id" : ObjectId("624a79c6bbaaee76910e3e09"), "name" : "Tom", "age" : 18 }

(7)切换到admin数据库,并关闭MongoDB数据库服务器端。

powershell 复制代码
> use admin
> db.shutdownServer()
> exit

(8)重新启动MongoDB服务器端,并使用mongoshell连接MongoDB

powershell 复制代码
mongod --config /data/memory/memory.conf
mongo --port 27019

(9)查看当前MongoDB实例中的数据库。

powershell 复制代码
> show dbs;

输出的信息如下:
admin  0.000GB
local  0.000GB

提示:因为使用In-Memory存储引擎,MongoDB不会执行数据的持久化操作。一旦重启了MongoDB数据库服务器,数据将会从内存中丢失。

相关推荐
weelinking1 小时前
【产品】12_接入数据库——让数据永久保存
jvm·数据库·python·react.js·数据挖掘·前端框架·产品经理
稳联技术老娜1 小时前
DeviceNet主站怎么连接西门子PLC,Profinet网关配置手册(那智机器人)
服务器·网络·数据库
这个DBA有点耶1 小时前
云上运维新挑战:当数据库不再“看得见摸得着”
数据库·sql·程序人生·云原生·运维开发·学习方法·dba
AskHarries2 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
消失在人海中3 小时前
oracle 数据库多表关联查询
服务器·数据库·oracle
九皇叔叔3 小时前
PostgreSQL/openGauss pg_stats 视图从入门到精通:统计信息、执行计划与慢 SQL 优化实战
数据库·sql·postgresql
南极企鹅4 小时前
MySQL间隙锁&临键锁
数据库·sql·mysql
TDengine (老段)5 小时前
TDengine 压缩编码机制 — 双层压缩架构与类型特化算法
大数据·数据库·物联网·算法·时序数据库·tdengine·涛思数据
苏渡苇6 小时前
Redis 持久化——RDB 快照 vs AOF 日志
数据库·redis·缓存·redis持久化·aof vs rdb
l1t6 小时前
DeepSeek总结的使用 PEG 实现运行时可扩展的 SQL 解析器
数据库·sql