redis底层数据存储模型之redisObject

       我们知道redis是基于内存,并且以key-value的形式存储数据的一种NoSQL数据库,支持数据持久化。首先,redis是使用C语言进行编写的,所以我们可以在redis目录下的src里面看到很多的以.o,.c,.h结尾的文件。


        今天我要介绍的就是redisObject这个对象了,他也是我们使用redis存储之后,实际在内存中保存的对象,我画了下面这张图来解释。


其中数据类型我们知道有string,list,hash,set,zset这五种。

type myKey     查看键为myKey的值类型。

编码方式有raw,int,ht,zipmap,ziplist,linkedlist,intset这些

object encoding myKey     查看键对应的编码方式。

       数据指针指向一个SDS抽象对象,这个对象由三部分组成。redis所有的键都是都是字符串,所以字符串在redis中有着特别的意义,redis对于字符串的存储有着很好的设计。SDS对象中的len表示char数组的长度,free表示空闲长度,然后再包括一个尾部标识‘\0’。这样我们就可以轻易的知道该键对应的值长度了,并且可以高效的执行append操作,因为提前分配的free部分可以降低内存的分配次数,从而加快追加操作的速度,缺点就是需要多占用内存空间,并且不会主动释放。buf数组是一个char数组,这里面才是我们真正存放的数据所在地,如上图所示(概念图),hello是我们的数据,尾部标识‘\0’,外加三个空闲区域。

object idletime myKey     查看对象最后一次被访问的时间

object refcount myKey     查看当前对象有多少引用(共享对象)

info     查看信息

info memory      查看单独内存信息

额外:

    开启redis服务:切换到redis/src目录下,执行redis-server 

    开启客户端:切换到redis/src目录下,执行redis-cli

    推出客户端: quit

    关闭redis服务:在客户端输入shutdown

    杀死redis服务:找到redis服务进程, ps aux | grep redis

                          杀死进程,kill -9 pid