2. jason在多处理器下的一个实验
3. 原理
arena+TLS
arena即小块内存,指将大内存划分成多个小内存来管理
TLS(Thread-local storage),即线程局部缓存
回过头来看看tcmalloc,惊人的一致。
经过测试,tcmalloc和jemalloc在实际应用中不相伯仲,一个比较早的测试结果:
valgrind检测不出tcmalloc和jemalloc的内存泄露,但是tcmalloc有gprof可以使用,还不清楚jemalloc有没有什么可用的检测工具
4. 安装使用(jemalloc当前版本2.2.5)
安装:
wget http://www.canonware.com/download/jemalloc/jemalloc-2.2.5.tar.bz2 .
tar -jxvf jemalloc-2.2.5.tar.bz2
cd jemalloc-2.2.5/ && ./configure && make && make install
ldconfig
使用:链接即可使用
写一个简单的测试程序client.cpp
g++ -o client client.cpp -ljemalloc
使用ldd查看程序所需的共享库
$ ldd client
linux-gate.so.1 => (0x00e18000)
libjemalloc.so.1 => /usr/local/lib/libjemalloc.so.1 (0x00110000)
libstdc++.so.6 => /usr/lib/libstdc++.so.6 (0x00322000)
libm.so.6 => /lib/libm.so.6 (0x0012d000)
libgcc_s.so.1 => /lib/libgcc_s.so.1 (0x002ed000)
libc.so.6 => /lib/libc.so.6 (0x00153000)
libpthread.so.0 => /lib/libpthread.so.0 (0x0080f000)
libdl.so.2 => /lib/libdl.so.2 (0x0069e000)
/lib/ld-linux.so.2 (0x008ab000)
以上方式是使用动态库,不推荐,更好地方式是使用静态库libjemalloc.a*
5. 其它
还有宣称比tcmalloc和jemalloc更快的内存管理库,eg:nedmalloc,有时间了再做了解~
references:
paper:A Scalable Concurrent malloc Implementation for FreeBSD
www.canonware.com/jemalloc/index.html