Maison > base de données > tutoriel mysql > Redis 的内存分配

Redis 的内存分配

WBOY
Libérer: 2016-06-07 16:39:21
original
1567 Les gens l'ont consulté

Redis 使用 zmalloc 进行内存分配,zmalloc下层使用 tcmallc 或者 jemalloc,它们在多线程并发的情况下比 glibc malloc 性能要好。下面四个函数被替换: malloc calloc realloc free zmalloc 主要是为每段分配内存额外增加一个8字节的头部,这个头部记录了此

Redis 使用 zmalloc 进行内存分配,zmalloc下层使用 tcmallc 或者 jemalloc,它们在多线程并发的情况下比 glibc malloc 性能要好。下面四个函数被替换:

  • malloc
  • calloc
  • realloc
  • free

zmalloc 主要是为每段分配内存额外增加一个8字节的头部,这个头部记录了此次分配的内存的长度。zmalloc等函数会自动处理偏移,用户无需知道头部的存在。

zmalloc 定义了 used_memory 记录当前一共分配出去了多少内存。

为了评估内存碎片的问题,Redis 需要知道进程实际消耗了多少内存(RSS,resident set size),这主要使用操作系统提供的接口。

  • Linux:每个进程在/proc 目录下有一个自己的目录,按进程 ID 命名,读取 stat 文件的第24个域就可以得到进程使用的内存用量;
  • Apple:使用 task_info获取当前进程的 task_basic_info,其中 resident_size就是内存用量。

计算 RSS/used_memory 即可知道目前碎片问题的严重程度,越大越严重。

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal