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作为内存分配器,如果没有记录,则需要排查。

相关推荐
SarL EMEN1 小时前
mysql之联合索引
数据库·mysql
l1t1 小时前
DeepSeek总结的DuckDB anofox-forecast季节调整时间序列预测插件功能
开发语言·数据库
meta INGU1 小时前
mysql数据被误删的恢复方案
数据库·mysql
27669582922 小时前
acw_sc__v2
数据库·acw_sc__v2·acw_sc__v2逆向·acw_sc__v2算法分析·acw_sc__v2分析·acw_sc__v2还原·acw_sc__v2-ck
Empty-Filled2 小时前
Claude Gateway 排查教程
网络·数据库·人工智能
椰猫子2 小时前
SpringMVC(SpringMVC简介、请求与响应(请求映射路径、请求参数、日期类型参数传递、响应json数据))
java·前端·数据库
2401_882273722 小时前
pattern属性在旧版Android浏览器无效怎么办_手动验证补充【操作】
jvm·数据库·python
小的~~2 小时前
Milvus会存在SQL注入攻击吗?
数据库·sql·milvus
uElY ITER2 小时前
MySQL官网驱动下载(jar包驱动和ODBC驱动)【详细教程】
数据库·mysql
NCIN EXPE2 小时前
MySQL--》理解锁机制中的并发控制与优化策略
数据库·mysql·oracle