Chinaunix首页 | 论坛 | 博客
  • 博客访问: 625859
  • 博文数量: 110
  • 博客积分: 3808
  • 博客等级: 中校
  • 技术积分: 1930
  • 用 户 组: 普通用户
  • 注册时间: 2010-05-15 14:32
个人简介

声的伟大!

文章分类

全部博文(110)

文章存档

2014年(1)

2013年(2)

2012年(12)

2011年(81)

2010年(14)

分类: Mysql/postgreSQL

2012-09-06 15:42:22

TCMalloc的全称为Thread-Caching Malloc,是谷歌开发的开源工具“google-perftools”中的一个成员。与标准的glibc库的malloc相比,TCMalloc库在内存分配效率和速度上要高很多,这

在很大程度上提高了服务器在高并发情况下的性能,从而降低系统负载。
要安装TCMalloc库,需要安装libunwind(32位操作系统不需要安装)和google-perftools两个软件包,libunwind库为基于64位CPU和操作系统的程序提供了基本函数调用链和函数调用寄存器

功能。下面介绍利用TCMalloc优化MySQL的具体操作过程:

1.安装libunwind库
可以从下载相应的libunwind版本。
# tar xvf libunwind-1.0.tar.gz 
# cd libunwind-1.0
# CFLAGS=-fPIC ./configure
# make CFLAGS=-fPIC
# make CFLAGS=-fPIC install

2.安装google-perftools
# tar xvf gperftools-2.0.tar.gz 
# cd gperftools-2.0
# ./configure 
# make && make install
# echo "/usr/local/lib" > /etc/ld.so.conf.d/usr_local_lib.conf
# ldconfig 
至此,google-perftools安装完成。


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

在# executing mysqld_safe的下一行,加上:
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
阅读(3128) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~