我的问题示例:HMSET myhash field1 value1 field2 value2
和my散列只有这两个字段。
主要问题是如何计算hash-max-ziplist-value
,使我的散列不会超过以压缩格式维护散列的值,从而将内存使用量降到最低。
非常感谢“凯文·克里斯托弗·亨利”对他的详细解释、帮助和时间。由于我的英语能力有限,我将在这里总结凯文的回答。如果我理解错了,请纠正我。
(1)为了满足hash-max-ziplist-value
,我需要计算最大(field1
,value1
,field2
,value2
)。假设value1
的大小最大。然后,我只需要确保value1
的大小不超过hash-max-ziplist-value
。
(2)要计算value1
,只需计算大小的字节数即可。因为hash-max-ziplist-value
是任何压缩之前字符串值的字节数。
(3)为了计算value1
的字节数,有很多种方法,其中之一是:首先,如果没有,则将value1
转换为UTF8编码。其次,使用客户端语言检查它的长度。因为UTF8编码字符串的长度是大小的字节数。(例如:utf8.encode(value1).length
)。
原始邮政
例如,HMSET myhash field1 value1 field2 value2
hash-max-ziplist-entries
的真正含义。上面的例子是一个条目还是两个条目,因为它有两个字段?
hash-max-ziplist-value
是什么?的大小,以字节为单位(a) MEMORY USAGE myhash
(b) field1
、value1
、field2
、value2
的总和
(c) value1
和value2
的总和。
(d) max(value1
,value2
)?
(e)最大(field1
+value1
,field2
+value2
)
hash-max-ziplist-value
。hash-max-ziplist-value
是字节的大小吗?那是utf-8编码的字符串长度吗?在redis中是否有用于此计算的现有命令?非常感谢你的帮助。
发布于 2019-06-05 05:08:47
这些值在redis.conf
文件以及内存优化文档中都有简要描述。
当哈希有少量的条目时,使用内存高效的数据结构进行编码,并且最大条目不超过给定的阈值。可以使用以下指令配置这些阈值。散列-最大值-ziplist-条目512 散列-最大值-ziplist-值64
使用这些默认值作为示例,如果哈希包含512或更少的条目,且每个条目为64字节或更小,则哈希将使用ziplist进行编码。
尽管文档没有确切说明哈希条目的大小是如何计算的,但是查看源代码表明字段名和值都必须小于或等于阈值。您应该能够通过计算二进制字符串的长度(以字节为单位)来确定大小。
为了回答你的一些具体问题:
上面的例子是一个条目还是两个条目,因为它有两个字段?
二。
hash-max-ziplist-value
是什么?
使用您的术语,这将是max(field1, value1, field2, value2)
。
那是utf-8编码的字符串计算吗?
Redis处理二进制字符串。这取决于您(或您的客户)决定使用什么编码。
有什么简单的方法来计算
hash-max-ziplist-value
的myhash值(以字节为单位)?在redis中是否存在用于此计算的命令?
据我所知,并不是这样,但是值的二进制字符串表示形式的长度应该大致正确。
https://stackoverflow.com/questions/56459786
复制