我需要在Aerospike中保存数据.这个引擎支持’bins'(‘bin’就像记录中的行或字段中的列).另一方面,我可以将我的记录保存为序列化blob.记录以原子方式从数据库中提取.也就是说,我不需要获取记录的某些“列”,我需要完全记录.
问题是:在性能方面保持此类方案数据的最有效方法是什么?保持它不反序列化并使用’bins’来描述所有记录的字段,或将其存储为1列中的序列化blob?
如果您确定您唯一的用例是获取完整记录,而不是单个bin,则最好将其存储为单个bin值. (在内部,多个bin将需要超出大小限制的多个malloc).事实上,您可以设置命名空间配置选项’single-bin true’,这将进一步优化事物.请注意,一旦设置了此配置选项,即使重新启动节点也不会取消设置.如果要更改此配置,则必须清理驱动器.如果命名空间在内存中,显然,此限制不适用.
在将来,如果有可能访问垃圾箱的子集,则存储为垃圾箱更好.因为它将节省网络I / O,这将比malloc开销大得多.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。