jemalloc是facebook推出的

https://github.com/jemalloc/jemalloc

http://jemalloc.net/

源码里面有INSTALL.md,里面有安装说明,但是不可完全参照,需要调整步骤如下:

先准备好gcc编译环境,然后把docbook-style-xsl依赖库安装好。

[root@localhost ]# yum -y install docbook-style-xsl

如果没有docbook-style-xsl,运行make dist会报错:

[root@localhost ]# make dist
/usr/bin/xsltproc -o doc/jemalloc.html doc/html.xsl doc/jemalloc.xml
warning: failed to load external entity "/html/docbook.xsl"
compilation error: file doc/html.xsl line 2 element import
xsl:import : unable to load /html/docbook.xsl
make: *** [doc/jemalloc.html] Error 5
 

正式开始编译:

chmod -R 777 jemalloc-4.5.0

cd  jemalloc-4.5.0

./autogen.sh --with-jemalloc-prefix=je_
make dist
make
make install

 

最终头文件和库文件的安装路径分别是:

usr/local/include/jemalloc 
usr/local/lib

 

本人环境是CentOS 7.3,gcc版本是4.8.5。

请注意:

(1)chmod这个步骤很重要,否则jemalloc文件夹下有大量.sh文件,最终会因为没有权限而编译失败。

(2)./autogen.sh 务必带上参数!即 "./autogen.sh --with-jemalloc-prefix=je_",否则将来编程调用时会报错,例如:

undefined reference to `je_malloc'

undefined reference to `je_realloc'

 

CMakeList.txt文件

cmake_minimum_required(VERSION 2.8)

project(myDemo)

SET(JEMALLOC_INCLUDE_DIR /usr/include/jemalloc)
SET(JEMALLOC_LIB /usr/local/lib)

INCLUDE_DIRECTORIES(${JEMALLOC_INCLUDE_DIR})

LINK_DIRECTORIES(${JEMALLOC_LIB})

#ADD_EXECUTABLE必须在TARGET_LINK_LIBRARIES前面,否则会报错
ADD_EXECUTABLE(${PROJECT_NAME} main.c)
TARGET_LINK_LIBRARIES(${PROJECT_NAME} jemalloc)

 

 

----

引申阅读TCMalloc
TcMalloc(Thread-CachingMalloc)是google-perftools工具中的一个内存管理库,所以一般提到tcmalloc,其实就是指使用gperftools,编译tcmalloc也就是编译gperftools。 与标准的glibc库中malloc相比,TcMalloc在内存分配的效率和速度上要高很多,可以提升高并发情况下的性能,降低系统的负载。

TcMalloc比glibc的malloc具有更高的效率。如在主频为2.84GH的pc上,Glibc的malloc需要使用300ns的时间来执行malloc/free对,而tcmalloc只需要50ns来完成相同的操作(数据来自官方文档)。

TcMalloc使用线程内存池的方法,小对象(<=32K)是在内存池中进行分配,使用分配较多的内存空间来优化分配时间,并定时进行垃圾回收操作。而大对象(>32K)则直接在全局控制堆中分配。Tcmalloc可以有效减小多线程间的锁争用问题,对于小对象,甚至可以实现0争用。

TCMalloc是gperftools的一部分,除TCMalloc外,gperftools还包括heap-checker、heap-profiler和cpu-profiler。

https://github.com/gperftools/gperftools

https://www.jianshu.com/p/11082b443ddf

 

 

Logo

更多推荐