Aerospike:保持数据为blob还是使用’bins’?

我需要在Aerospike中保存数据.这个引擎支持’bins'(‘bin’就像记录中的行或字段中的列).另一方面,我可以将我的记录保存为序列化blob.记录以原子方式从数据库中提取.也就是说,我不需要获取记录的某些“列”,我需要完全记录.

问题是:在性能方面保持此类方案数据的最有效方法是什么?保持它不反序列化并使用’bins’来描述所有记录的字段,或将其存储为1列中的序列化blob?

如果您确定您唯一的用例是获取完整记录,而不是单个bin,则最好将其存储为单个bin值. (在内部,多个bin将需要超出大小限制的多个malloc).事实上,您可以设置命名空间配置选项’single-bin true’,这将进一步优化事物.请注意,一旦设置了此配置选项,即使重新启动节点也不会取消设置.如果要更改此配置,则必须清理驱动器.如果命名空间在内存中,显然,此限制不适用.

在将来,如果有可能访问垃圾箱的子集,则存储为垃圾箱更好.因为它将节省网络I / O,这将比malloc开销大得多.

相关文章

校园网上订餐系统系统主要功能模块包括公告内容(公告栏、轮...
从今天开始,正式进入项目阶段。本次的项目是跟着黑马的瑞吉...
在可预见的将来,IT不会萎缩,只会越发展越庞大,最终会渗透...
vulntarget-b靶场最详细通关记录。
MongoDB是一个开源、高性能、支持海量数据存储的。
【NoSQL数据库技术与应用】课本代码、课后答案(持续更新)