网友回复
在 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%