利用Tcmalloc优化MySQL性能

本文介绍如何使用TCMalloc提升MySQL在高并发环境下的内存管理稳定性。通过安装配置TCMalloc及libunwind库,并修改MySQL启动脚本,实现内存分配效率的优化。

TCMalloc (google-perftools) 是用于优化C++写的多线程应用,比glibc 2.3的malloc快。这个模块可以用来让MySQL在高并发下内存占用更加稳定。

由于google被墙,gperftools-2.1.tar.gz需要到墙外下载。目前已经上传至http://down.51cto.com/data/1332597


google-perftools包含四个工具,分别是:TCMallocheap-checkerheap-profilercpu-profiler,TCMalloc是google-perftools的其中一个工具,用于优化内存分配的效率和速度,帮助在高并发的情况下很好的控制内存的使用。

1.64位操作系统请先安装 libunwind库,32位操作系统不要安装。libunwind库为基于64位CPU和操作系统的程序提供了基本的堆栈辗转开解功能,其中包括用于输出堆栈跟踪的API、用于以编程方式辗转开解堆栈的API以及支持C++异常处理机制的API。

1
2
3
4
5
tar  zxvf libunwind-1.1. tar .gz
cd  libunwind-1.1
. /configure
make
make  install

2.安装google-perftools:

1
2
3
4
5
tar  zxvf google-perftools-2.1. tar .gz
cd  google-perftools-2.1
. /configure
make
make  install

3.运行以下二行命令

1
2
echo  "/usr/local/lib"  /etc/ld .so.conf.d /usr_local_lib .conf
/sbin/ldconfig

4.修改MySQL启动脚本

1
2
3
4
5
6
7
[root@Node1 ~] # whereis mysqld_safe
#用于找到mysqld_safe文件的位置
mysqld_safe:  /usr/bin/mysqld_safe  /usr/share/man/man1/mysqld_safe .1.gz
[root@Node1 ~] # vim /usr/bin/mysqld_safe
# executing mysqld_safe的下一行,加上:
export  LD_PRELOAD= /usr/local/lib/libtcmalloc .so
保存后退出,然后重启MySQL服务器。

wKioL1Ob5-Cg-L2YAAAfnLk1jPM231.png

5.测试是否正常

wKioL1Ob6I6jRrogAAANrl1ei3Q926.png

如出现以上说明安装成功,另外可能出现lsof未安装,使用yum -y install lsof即可。




本文转自 rong341233 51CTO博客,原文链接:http://blog.51cto.com/fengwan/1426297
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值