我正在开发一种产品,作为其操作的一部分,必须跟踪大量文件/目录.我们的想法是将数据信息存储在数据库中,然后在启动时为每个文件创建监视.更改的文件将排队(在数据库中),以便将组同步到远程数据库.它们将按优先顺序同步,数字在1-10之间.
数据库信息:
>< 100,000条状态信息
>在引导时读取整个数据库,只需要文件路径
>排队的文件将具有优先级字段(不需要搜索任何其他内容)
>插入可能很慢
> Redis-将文件路径存储为密钥,将stat数据存储为值;队列将是一个列表
> MongoDB-比Redis更多的查询选项,但仍然很快
我认为Nosql数据库在这里是最好的解决方案,因为没有太多的关系逻辑正在进行,并且总数据大小不是太大(类似于<100 mb,接近<30 mb) ).我确实看过sqlite,因为它似乎很简单,可以嵌入到可安装的应用程序中. 由于这是最终用户的分布式应用程序而不是高负载服务器,因此数据库不必支持许多并发用户.这里的主要优先事项是找到一个模型最有意义的数据库. 那么问题是哪个数据库最适合这种情况? 此外,是否有任何其他数据库对这样的应用程序更有意义?
解决方法
@H_403_19@ 首先想到的是我熟悉的特定RDBMS.但是,我认识到它可能不是这个应用程序的最佳选择.所以,我的建议是使用您熟悉的数据库.如果您熟悉Redis或MongoDB,那么请选择其中一个.如果您对sqlite更熟悉,那就选择它.