使用Google的开源TCMalloc库提高MySQL在高并发情况下的性能

本文连接http://blog.opvps.com/google-tcmalloc-mysql/

TCMalloc的全称为Thread-Caching Malloc,是谷歌开发的开源工具“google-perftools”中的一个成员。与标准的glibc库的malloc相比,TCMalloc库在内存分配效率和速度上要高很多,这在很大程度上提高了服务器在高并发情况下的性能,从而降低系统负载。要安装TCMalloc库,需要安装libunwind(32位操作系统不需要安装)和google-perftools两个软件包,libunwind库为基于64位CPU和操作系统的程序提供了基本函数调用链和函数调用寄存器

安装方法如下:

1.安装libunwind库
可以从http://download.savannah.gnu.org/releases/libunwind下载相应的libunwind版本。
# wget http://ftp.twaren.net/Unix/NonGNU//libunwind/libunwind-1.1.tar.gz
# tar xf libunwind-1.1.tar.gz
# cd libunwind-1.1
# CFLAGS=-fPIC ./configure
# make CFLAGS=-fPIC
# make CFLAGS=-fPIC install

2.安装google-perftools 下载地址http://code.google.com/p/gperftools/downloads/list
wget http://gperftools.googlecode.com/files/gperftools-2.0.tar.gz
# tar xvf gperftools-2.0.tar.gz
# cd gperftools-2.0
# ./configure
# make && make install
# echo “/usr/local/lib” > /etc/ld.so.conf.d/opvps.conf
# ldconfig
至此,google-perftools安装完成。

3.修改MySQL启动脚本(根据你的MySQL安装位置而定):
vi /usr/local/mysql/bin/mysqld_safe

在# executing mysqldsafe的下一行,加上:
export LD
PRELOAD=/usr/local/lib/libtcmalloc.so
保存后退出,然后重启MySQL服务器。

4.使用lsof命令查看tcmalloc是否起效:
lsof -n |grep tcmalloc

显示如下信息,说明tcmalloc已经起效:
mysqld    23073     mysql  mem       REG      253,0    1727356    5865483 /usr/local/lib/libtcmalloc.so.4.1.0