您的位置:首页 > 数据库 > Redis

redis中可以使用的内存分配的库和redis默认是被build成32位的可执行程序

2018-03-01 11:27 597 查看
在redis中的makefile中,可以看到redis可以使用四种内存管理的库分别是glibc/jemalloc/tcmalloc/tcmalloc_minimal
从Makefile中可以看出如果是linux系统的话,默认用的是jemalloc
# Default allocator
ifeq ($(uname_S),Linux)
MALLOC=jemalloc
else
MALLOC=libc
endif
#如果指定USE_TCMALLOC的话,则使用tcmalloc
# Backwards compatibility for selecting an allocator
ifeq ($(USE_TCMALLOC),yes)
MALLOC=tcmalloc
endif

ifeq ($(USE_TCMALLOC_MINIMAL),yes)
MALLOC=tcmalloc_minimal
endif

ifeq ($(USE_JEMALLOC),yes)
MALLOC=jemalloc
endif
由于makefile中的赋值是从上到下的,因此如果用户同时指定USE_TCMALLOC/USE_TCMALLOC_MINIMAL/USE_JEMALLOC
那以最后一次的赋值为准,即使用jemalloc.
从makefile中还可以知道redis源码编译时默认的优化等级是O3。可以调整为O3试试,OPTIMIZATION?=-O2
从这个目标可以知道,redis默认是被build成32 bit的应用程序的。

32bit:
@echo ""
@echo "WARNING: if it fails under Linux you probably need to install libc6-dev-i386"
@echo ""
$(MAKE) CFLAGS="-m32" LDFLAGS="-m32"
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐