什么是内存数据库?数据如何存储?如果数据记录存储在内存中,当电脑或服务器重启后,数据还有吗?

什么是内存数据库?数据如何存储?如果数据记录存储在内存中,当电脑或服务器重启后,数据还有吗?,第1张

当然有产品了,但是目前没有一家的内存数据库能否占领市场的高度,因为内存数据库的专业化需求太不一样了。

各大公司用的内存数据库基本上都是自己搞得,借鉴一些数据库的理论或开源内存数据库的源码,结合自己的项目,定制化开发的。

内存数据库可以将数据同步到文件中,即redo机制。所以当服务器重启后,数据也不会丢失。

最近我们也在搞这方面的产品

方式一:使用tmpfs作为文件系统

方式二:使用ramfs作为文件系统

这两种方式的思路都差不多,使用一个内存模拟文件系统,由于替换了磁盘文件系统,数据就保留在内存中。

方式三:修改源码设置in_memory参数

其实wiredtiger本身就支持将数据保留在内存中不刷盘,MongoDB的内存引擎估计也是利用wt的这一特性。wiredtiger.in文件中,wiredtiger_open()函数会传入配置信息config,函数前面的注释详细解释了有哪些配置项,其中就列出了in_memory配置,如下图说明。

如果修改源码传入in_memory=true编译还是会报错,提示incompatible argument in-memor。

报上述错误是因为开源版本对这个参数进行了检查,如果设置了就会传回错误码,修改方式很简单,令它不返回错误码就行了。

就这样我们将MongoDB改成了内存数据库。

由上至下的文件位置分别在:

src/third_party/wiredtiger/src/include/wiredtiger.in

src/mongo/db/storage/wiredtiger/wiredtiger_kv_engine.cpp

src/third_party/wiredtiger/src/conn/conn_ckpt.c

最近重新使用这个内存数据库,发现报出新的错误,提示in_memory与log不能同时设置,这个log的设置默认为true,如果指定nojournal,那么会置为false。不过先检查后重置,所以报错。

解决方法是在检查之前就加入log=(enabled=false)


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/6757653.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-27
下一篇2023-03-27

发表评论

登录后才能评论

评论列表(0条)

    保存