02-Redis内存划分

Redis作为内存数据库,在内存中存储的主要内容是数据(键值对)

数据

数据是Redis中存储的主要内容,这部分占用的内存会统计在used_memory中
Redis使用键值对存储数据,其中的值(对象)包含5种类型,即字符串、哈希、列表、集合、有序集合。
这5种类型是Redis对外提供的,实际上,在Redis内部,每种类型可能有2种或更多的内部编码实现
此外,Redis在存储对象时,并不是直接将数据扔进内存,而是会对对象进行各种包装:如redisObject、SDS等;

进程内存

Redis主进程本身运行肯定需要占用内存,如代码、常量池等等;这部分内存大约几兆,在大多数生产环境中与Redis数据占用的内存相比可以忽略。这部分内存不是由jemalloc分配,因此不会统计在used_memory中。

除了主进程外,Redis创建的子进程运行也会占用内存,如Redis执行AOF、RDB重写时创建的子进程。当然,这部分内存不属于Redis进程,也不会统计在used_memory和used_memory_rss中。

缓冲内存

缓冲内存包括客户端缓冲区复制积压缓冲区AOF缓冲区等

  • 客户端缓冲存储客户端连接的输入输出缓冲
  • 复制积压缓冲用于部分复制功能
  • AOF缓冲区用于在进行AOF重写时,保存最近的写入命令

这部分内存由jemalloc分配,因此会统计在used_memory中

内存碎片

内存碎片是Redis在分配、回收物理内存过程中产生的。
例如,如果对数据的更改频繁,而且数据之间的大小相差很大,可能导致redis释放的空间在物理内存中并没有释放,但redis又无法有效利用,这就形成了内存碎片。
内存碎片不会统计在used_memory中。内存碎片的产生与对数据进行的操作、数据的特点等都有关

如果内存分配器设计合理,可以尽可能的减少内存碎片的产生。
如果Redis服务器中的内存碎片已经很大,可以通过安全重启的方式减小内存碎片:因为重启之后,Redis重新从备份文件中读取数据,在内存中进行重排,为每个数据重新选择合适的内存单元,减小内存碎片。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 Redis是目前最火爆的内存数据库之一,通过在内存中读写数据,大大提高了读写速度,可以说Redis是实现网站...
    小陈阿飞阅读 812评论 0 1
  • 转载:可能是目前最详细的Redis内存模型及应用解读 Redis是目前最火爆的内存数据库之一,通过在内存中读写数据...
    jwnba24阅读 633评论 0 4
  • 几个常用了命令行 登录 redis-cli -h 127.0.0.1 -p 6379 -a 123 查看内存 in...
    lucode阅读 1,008评论 0 2
  • (五)赶集 观音塘一年有3次庙会,我们正好赶上。 这一天,上末村横竖三条街的两旁都摆满了摊位。又长又密,估计得有好...
    就当活着是旅行阅读 300评论 4 2
  • ib和杀戮,garry和ib以及ray和zack。 靠谱(。的成年男性和小女孩的组合特别好!!! 还有胜出和瑞金这...
    入梦安眠阅读 256评论 0 0