MySQL使用jemalloc作为内存分配器

一、背景

数据库服务器内存告警,服务器的内存是512G,数据库innodb_buffer_pool_size分配了384G内存,随着时间推移,内存占用慢慢趋近于384G,而后开始使用服务器的交换空间(虚拟内存),跟服务器运维工程师沟通得知,这个虚拟内存实际是使用的磁盘空间,这样可能会影响到数据库服务的读写,所以开始研究分析,要如何解决。

二、方案选型

根据查阅相关资料,了解到MySQL默认是使用glibc作为内存分配器的,而市面上也有其他独立的内存分配器,如jemalloc、tcmalloc等。

jemalloc和tcmalloc的对比请参考:

内存分配器对比:jemalloc vs tcmalloc 的性能测试与选型_tcmalloc jemalloc对比-CSDN博客

三、jemalloc安装

1、下载地址:

Releases · jemalloc/jemalloc

2、解压安装包:

tar -jxvf jemalloc-5.3.0.tar.bz2

注:解压报错,执行:sudo yum -y install bzip2

3、编译安装:

复制代码
./autogen.sh

make -j8

sudo make install

ldconfig

4、修改配置:

找到mysql安装路径,在bin目录下有一个mysqld_safe的文件,打开文件在顶部加上:

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

复制代码
# MySQL 安装根目录
basedir=/tools/mysql/mysql8

# 编辑mysqld_safe文件
vi /tools/mysql/mysql8/bin/mysqld_safe

# 加入以下内容
export LD_PRELOAD=/usr/local/lib/libjemalloc.so.2

# /usr/local/lib/libjemalloc.so.2 是jemalloc的默认路径

5、重启MySQL

sudo service mysql restart

四、验证

命令:

sudo lsof -p `pidof mysqld` | grep -i jemalloc

结果:

如果有指向jemalloc默认路径的记录,则说明mysql有成功使用jemalloc作为内存分配器,如果没有记录,则需要排查。

相关推荐
小短腿的代码世界6 分钟前
Qt国际化深度解析:从源码到企业级多语言实践
java·数据库·qt
Ting-yu12 分钟前
Spring AI Alibaba零基础速成(6) ---- 向量化
数据库·人工智能
dishugj28 分钟前
HANA性能分析视图
数据库
l1t1 小时前
DeepSeek总结的在 DuckDB 中试驾 Lance 数据湖仓格式
数据库·人工智能·机器学习·duckdb
PaperData1 小时前
2017-2025年中国10米分辨率土地利用/覆盖栅格数据(from Esri LULC)
数据库·数据分析·学习方法
小二·1 小时前
LangGraph 多智能体实战:从零搭建 Multi-Agent 协作系统
java·开发语言·数据库
羑悻的小杀马特2 小时前
工业时序数据选型的几点思考:从存储成本与查询延迟说起
数据库·人工智能
小旭95272 小时前
商品详情实现与缓存问题(穿透、击穿、雪崩)解决方案
java·数据库·spring boot·后端·缓存
我本楚狂人www2 小时前
Spring 两大核心思想(一):IoC
java·数据库·spring
熊文豪3 小时前
标量子查询消除:一次让查询性能提升千倍的优化器手术
数据库·电科金仓