0

0

Redis如何采用不同内存分配器碎片率对比

WBOY

WBOY

发布时间:2023-05-26 10:58:21

|

1791人浏览过

|

来源于亿速云

转载

  在redis的 zmalloc.c 源码中,我们可以看到如下代码:

  /* Explicitly override malloc/free etc when using tcmalloc. */

  #if defined(USE_TCMALLOC)

  #define malloc(size) tc_malloc(size)

tc_calloc(count,size)是calloc函数的定义

  #define realloc(ptr,size) tc_realloc(ptr,size)

  #define free(ptr) tc_free(ptr)

  #elif defined(USE_JEMALLOC)

  #define malloc(size) je_malloc(size)

The following sentence is rewritten as requested: The statement "#define calloc(count,size) je_calloc(count,size)" is used to replace the standard defined function "calloc" with a custom function named "je_calloc".

  #define realloc(ptr,size) je_realloc(ptr,size)

  #define free(ptr) je_free(ptr)

  #endif

  从上面的代码中我们可以看到,Redis在编译时,会先判断是否使用tcmalloc,如果是,会用tcmalloc对应的函数替换掉标准的libc中的函数实现。在此之后,会检测jemalloc是否生效,如果不行,才会使用标准libc中的内存管理函数。

  而在最新的2.4.4版本中,jemalloc已经作为源码包的一部分包含在源码包中,所以可以直接被使用。而如果你要使用tcmalloc的话,是需要自己安装的。

  下面简单说一下如何安装tcmalloc包,tcmalloc是google-proftools中的一部分,所以我们实际上需要安装google-proftools。在64位机器上安装时,必须先安装其所需的libunwind库。

  wget http://download.savannah.gnu.org/releases/libunwind/libunwind-0.99-alpha.tar.gz

  tar zxvf libunwind-0.99-alpha.tar.gz

  cd libunwind-0.99-alpha/

  CFLAGS=-fPIC ./configure

  make CFLAGS=-fPIC

  make CFLAGS=-fPIC install

  Redis怎样采用不同内存分配器碎片率对比

  然后再进行google-preftools的安装:

  wget http://google-perftools.googlecode.com/files/google-perftools-1.8.1.tar.gz

  tar zxvf google-perftools-1.8.1.tar.gz

  cd google-perftools-1.8.1/

  ./configure --disable-cpu-profiler --disable-heap-profiler --disable-heap-checker --disable-debugalloc --enable-minimal

  make && make install

  sudo echo "/usr/local/lib" > /etc/ld.so.conf.d/usr_local_lib.conf #如果没有这个文件,自己建一个

  sudo /sbin/ldconfig

  然后再进行Redis的安装,在make时指定相应的参数以启用tcmalloc

PictoGraphic
PictoGraphic

AI驱动的矢量插图库和插图生成平台

下载

  $ curl -O http://redis.googlecode.com/files/redis-2.4.4.tar.gz

  $ tar xzvf redis-2.4.4.tar.gz

  $ cd redis-2.4.4

  $ make USE_TCMALLOC=yes FORCE_LIBC_MALLOC=yes

  $ sudo make install

  再启动Redis后通过info命令就能看到使用的内存分配器了。

回到本文的主题,本文讨论的是tcmalloc、jemalloc以及libc所对应的三个内存分配器。下面是一个简单的测试结果,摘自Redis info信息,旨在评估它的性能和碎片率。测试使用了不同的分配器。我们可以看到,采用tcmalloc时碎片率是最低的,为1.01,jemalloc为1.02,而libc的分配器碎片率为1.31,如下所未:

  used_memory:708391440

  used_menory_human:675.57M

  used_memory_rss:715169792

  used_memory_peak:708814040

  used_memory_peak_human:675.98M

  mem_fragmentation_ratio:1.01

  mem_allocator:tcmalloc-1.7

  used_memory:708381168

  used_menory_human:675.56M

  used_memory_rss:723587072

  used_memory_peak:708803768

  used_memory_peak_human:675.97M

  mem_fragmentation_ratio:1.02

  mem_allocator:jemalloc-2.2.1

  used_memory:869000400

  used_menory_human:828.74M

  used_memory_rss:1136689152

  used_memory_peak:868992208

  used_memory_peak_human:828.74M

  mem_fragmentation_ratio:1.31

  mem_allocator:libc

相关专题

更多
typedef和define区别
typedef和define区别

typedef和define区别在类型检查、作用范围、可读性、错误处理和内存占用等。本专题为大家提供typedef和define相关的文章、下载、课程内容,供大家免费下载体验。

105

2023.09.26

define的用法
define的用法

define用法:1、定义常量;2、定义函数宏:3、定义条件编译;4、定义多行宏。更多关于define的用法的内容,大家可以阅读本专题下的文章。

316

2023.10.11

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

713

2023.08.22

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

193

2023.11.20

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

424

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

172

2023.10.30

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

472

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

158

2023.10.07

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

177

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

Redis+MySQL数据库面试教程
Redis+MySQL数据库面试教程

共72课时 | 6.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号