天天看点

利用Tcmalloc优化MySQL性能

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

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

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

1

2

3

4

5

<code>tar</code> <code>zxvf libunwind-1.1.</code><code>tar</code><code>.gz</code>

<code>cd</code> <code>libunwind-1.1</code>

<code>.</code><code>/configure</code>

<code>make</code>

<code>make</code> <code>install</code>

2.安装google-perftools:

<code>tar</code> <code>zxvf google-perftools-2.1.</code><code>tar</code><code>.gz</code>

<code>cd</code> <code>google-perftools-2.1</code>

3.运行以下二行命令

<code>echo</code> <code>"/usr/local/lib"</code> <code>&gt; </code><code>/etc/ld</code><code>.so.conf.d</code><code>/usr_local_lib</code><code>.conf</code>

<code>/sbin/ldconfig</code>

4.修改MySQL启动脚本

6

7

<code>[root@Node1 ~]</code><code># whereis mysqld_safe</code>

<code>#用于找到mysqld_safe文件的位置</code>

<code>mysqld_safe: </code><code>/usr/bin/mysqld_safe</code> <code>/usr/share/man/man1/mysqld_safe</code><code>.1.gz</code>

<code>[root@Node1 ~]</code><code># vim /usr/bin/mysqld_safe</code>

<code>在</code><code># executing mysqld_safe的下一行,加上:</code>

<code>export</code> <code>LD_PRELOAD=</code><code>/usr/local/lib/libtcmalloc</code><code>.so</code>

<code>保存后退出,然后重启MySQL服务器。</code>

5.测试是否正常

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

本文转自 rong341233 51CTO博客,原文链接:http://blog.51cto.com/fengwan/1426297

继续阅读