如何将MongoDB改造成内存数据库

如何将MongoDB改造成内存数据库,第1张

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

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

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

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

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

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

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

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

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

src/third_party/wiredtiger/src/include/wiredtigerin

src/mongo/db/storage/wiredtiger/wiredtiger_kv_enginecpp

src/third_party/wiredtiger/src/conn/conn_ckptc

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

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

connecting to: test

> show dbs ->

MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。

数据库是按照数据结构来组织、存储和管理数据的仓库,它产生于距今六十多年前,随着信息技术和市场的发展,特别是二十世纪九十年代以后,数据管理不再仅仅是存储和管理数据,而转变成用户所需要的各种数据管理的方式。数据库有很多种类型,从最简单的存储有各种数据的表格到能够进行海量数据存储的大型数据库系统都在各个方面得到了广泛的应用。

在信息化社会,充分有效地管理和利用各类信息资源,是进行科学研究和决策管理的前提条件。数据库技术是管理信息系统、办公自动化系统、决策支持系统等各类信息系统的核心部分,是进行科学研究和决策管理的重要技术手段。感兴趣的话点击此处,了解一下

关于数据库的相关内容,可以到亿万克官网进行深入的了解,亿万克集服务器和存储等数据中心产品的研发、生产、销售、服务系统整合于一体,是民族高科技制造企业领导品牌 ,所有产品和技术完全拥有自主知识产权,应用领域涵盖云计算、数据中心、边缘计算、人工智能、金融、电信、教育、能源等,为客户提供全方位安全自主可控技术服务保障。

以上就是关于如何将MongoDB改造成内存数据库全部的内容,包括:如何将MongoDB改造成内存数据库、mongodb数据库如何生成数据字典、MongoDB是一个基于分布式文件存储的数据库,为WEB应用提供高性能的数据存储解决方案;等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: https://outofmemory.cn/sjk/9734883.html

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

发表评论

登录后才能评论

评论列表(0条)

保存