+
15
-

如何避免mysql等进程由于内存不足无法分配内存触发OOM Killer被杀?

如何避免mysql等进程由于内存不足无法分配内存触发OOM Killer被杀?

网友回复

+
24
-

1、增加物理内存

2、优化mysql的sql语句性能

3、mysql守护进程,被杀自动重启

4、mysql单独放在一个服务器,减少其他服务对他的影像

+
10
-

在 Linux 系统中,当内存不足时,OOM Killer(Out-Of-Memory Killer)会终止占用内存较多的进程,以释放内存。MySQL 等数据库进程通常占用大量内存,因此容易被 OOM Killer 选中。为了避免 MySQL 进程被 OOM Killer 杀死,可以采取以下措施:

1. 优化 MySQL 内存配置

合理配置 MySQL 的内存参数,避免过度占用系统内存。

关键参数innodb_buffer_pool_size:InnoDB 缓冲池大小,建议设置为物理内存的 50%-70%。key_buffer_size:MyISAM 索引缓存大小,如果使用 InnoDB 引擎,可以设置为较小值。query_cache_size:查询缓存大小,建议根据实际情况调整。tmp_table_size 和 max_heap_table_size:临时表大小,避免设置过大。示例
SET GLOBAL innodb_buffer_pool_size = 4G;
SET GLOBAL key_buffer_size = 256M;
SET GLOBAL query_cache_size = 128M;
SET GLOBAL tmp_table_size = 64M;
SET GLOBAL max_heap_table_size = 64M;
2. 限制 MySQL 的内存使用

通过 Linux 的 cgroups 或 ulimit 限制 MySQL 进程的内存使用。

使用 cgroups创建 cgroup:
sudo cgcreate -g memory:/mysql_group
设置内存限制:
echo 8G | sudo tee /sys/fs/cgroup/memory/mysql_group/memory.limit_in_bytes
将 MySQL 进程添加到 cgroup:
ec...

点击查看剩余70%

我知道答案,我要回答