Jemalloc优化MySQL和Nginx

Redis 2.4版本以后,默认使用jemalloc来作内存管理;tengine也整合jemalloc。jemalloc从各方评测的结果可见与google tcmalloc都不相伯仲,皆为内存管理器领域最高水平。以下图:css

图片来源: facebookhtml

最左边的就是glibc的malloc,最右边的就是jemalloc。从图表上能够看出,jemalloc的性能有glibc的两倍以上。很是压 倒性的性能差别。所以,使用了jemalloc的应用程序天然会快不少。Jemalloc旁边的就是tcmalloc。Tcmalloc的性能与其相差甚 微,低jemalloc2.1.0慢4.5%。图上和tcmalloc的1.4版本,而如今已经到2.1版本,所以实际上这二者应该是不相仲伯的。 Jemalloc的创始人jason evans也意识到这一点,说在cpu core 8以上的计算机上jemalloc效率更高。mysql

MySQL性能测试–jemalloc内存管理:http://www.linuxeye.com/Linux/1914.html
linux

安装jemalloc

cd lnmp/src
wget http://www.canonware.com/download/jemalloc/jemalloc-3.4.0.tar.bz2
tar xjf jemalloc-3.4.0.tar.bz2
cd jemalloc-3.4.0 ./configure
make && make install
echo '/usr/local/lib' > /etc/ld.so.conf.d/local.conf
ldconfig

使用jemalloc优化MySQL

方法1.

   MySQL/MaridDB 5.5编译方法,cmake预编译时加上下面参数nginx

-DCMAKE_EXE_LINKER_FLAGS="-ljemalloc" -DWITH_SAFEMALLOC=OFF


方法2.

    修改mysqld_safe直接加载:sql

    查找文件 /usr/local/mysql/bin/mysqld_safe
    在#executing mysqld_safe 下面加上
shell

  LD_PRELOAD=/usr/local/lib/libjemalloc.so

    从新启动MYSQL性能

    使用下面代码自动修改mysqld_safe文件优化

sed -i 's@executing mysqld_safe@executing mysqld_safe\nexport LD_PRELOAD=/usr/local/lib/libjemalloc.so@' /usr/local/mysql/bin/mysqld_safe
service mysqld restart



使用jemalloc优化Nginx

编译NGINX时添加如下参数:google

--with-ld-opt="-ljemalloc"

具体实现:

cd lnmp/src/nginx-1.4.2
make clean
./configure --prefix=/usr/local/nginx --user=www --group=www \  
--with-http_stub_status_module --with-http_ssl_module --with-http_flv_module \ 
--with-http_gzip_static_module --with-ld-opt="-ljemalloc"
make && make install

 验证 jemalloc 是否运行:

lsof -n | grep jemalloc
相关文章
相关标签/搜索