TCMalloc(Thread-Caching Malloc)是google开发的开源工具──“google-perftools”中的成员。与标准的glibc库的malloc相比,TCMalloc在内存的分配上效率和速度要高得多,可以在很大程度上提高MySQL服务器在高并发情况下的性能,降低系统负载。
TCMalloc库的安装步骤(Linux环境):
一、64位操作系统请先安装libunwind库(32位操作系统不要安装)
libunwind库为基于64位CPU和操作系统的程序提供了基本的堆栈辗转开解功能,其中包括用于输出堆栈跟踪的API、用于以编程方式辗转开解堆栈的API以及支持C++异常处理机制的API。1、到http://download.savannah.gnu.org/releases/libunwind目录中下载最新的libunwind包。
2、解压安装
tar zxvf libunwind-1.1.tar.gz
cd libunwind-1.1
CFLAGS=-fPIC ./configure
make CFLAGS=-fPIC
sudo make install
二、安装google-perftools:
wget http://google-perftools.googlecode.com/files/gperftools-2.1.tar.gz
tar zxvf gperftools-2.1.tar.gz
cd gperftools-2.1/
./configure
make
sudo make install
说明:./configure时可以使用--disable-cpu-profiler --disable-heap-profiler --disable-heap-checker --disable-debugalloc --enable-minimal等配置选项进行设置。
三、安装Redis
curl -O http://redis.googlecode.com/files/redis-2.6.14.tar.gz
tar xzvf redis-2.6.14.tar.gz
cd redis-2.6.14
make USE_TCMALLOC=yes
编译成功哄,src目录下会生成redis-server等几个可执行文件。
四、检查redis依赖
zhongcy@ubuntu-cfv2:~/zhongcy/tool/redis-2.6.14/src$ ldd redis-server
linux-vdso.so.1 => (0x00007fff0cdff000)
libm.so.6 => /lib/libm.so.6 (0x00007fbdac6bd000)
libtcmalloc.so.4 => not found
libpthread.so.0 => /lib/libpthread.so.0 (0x00007fbdac49f000)
libc.so.6 => /lib/libc.so.6 (0x00007fbdac118000)
/lib64/ld-linux-x86-64.so.2 (0x00007fbdac948000)
发现存在有些连接库找不到的问题,有以下2中方法解决。
4.1 添加环境变量
由于libtcmalloc.so安装在/usr/local/lib中,所以添加/usr/local/lib目录到LD_LIBRARY_PATH环境变量中
4.2 配置本地库
sudo echo "/usr/local/lib" > /etc/ld.so.conf.d/usr_local_lib.conf #如果没有这个文件,自己建一个 sudo /sbin/ldconfig
这样就从根本上解决的依赖问题。
5、运行redis
运行:./src/redis-server redis.conf
运行成功:
小小实践,如有哪里不足,欢迎指出。