前言
Redis数据结构容量评估的相关知识 ------ 想学的小伙伴可以移步Redis相关数据结构的容量评估 ,有了方面的知识,我们可以根据不同的场景来预估Redis会使用的内存容量。
那么这边博客就介绍一下,如果数据量达到千万甚至上亿级别时,该如何优化数据结构,节省内存空间。
Redis 数据结构和编码方式
继续回顾一下这张图,为什么Redis要对这些数据结构,分别设置多种编码方式(底层数据结构实现)呢?
肯定是有原因的,因为随着数据量的上涨,或者存储的键值本身的大小变化,都会影响到对应编码方式的选择,接下来会简单介绍一下集中编码的选择。这些编码结构可以参考我的另一篇博客Redis 底层数据结构和对象介绍
String对象优化
这个对象应该是我们最熟悉的一种了,Redis 的key值 不管是整形数字,还是浮点数,还是字符串,都会使用String 对象来表示。 那么value就不一定了
- 如果是整形数字,并且可以用long 表示,那么会用int编码
结构如下所示:(所有的底层结构最上层都会用RedisObject表示,详细内容上面给出的链接中有介绍)
- 如果是一个字符串值,且长度小于等于32字节,就会使用embstr编码