【YashanDB 知识库】如何避免 yasdb 进程被 Linux OOM Killer 杀掉
本文内容来自 YashanDB 官网,原文内容请见https://www.yashandb.com/newsinfo/7352693.html?templateId=1718516
在内存使用接近 100%时,系统处于危险境地,为了避免服务器崩溃,Linux 内核中有 OOM(Out Of Memory) Killer 进程,当内存使用接近满时,缺省它会找到使用内存最多的进程杀掉(kill -9)。这个机制保护系统不至于崩溃,但对于数据库服务器而言,通常数据库主进程是使用内存最多的那个,如果别的应用导致整个系统内存接近上限,数据库进程将成为 OOM Killer 的牺牲者。
避免数据库进程成为牺牲者的方法
方法一:OS 层面关闭 OOM Killer(root 用户操作)
echo "vm.oom-kill = 0" >> /etc/sysctl.conf
echo "vm.overcommit_memory = 2" >> /etc/sysctl.conf
reboot 生效
方法二:豁免数据库进程(数据库实例用户操作,需要有 sudo 权限)
sudo echo -1000> /proc/$(ps -u yashan|grep yasdb|awk '{print $1}')/oom_score_adj
需要将 yashan 替换成数据库实例用户
版权声明: 本文为 InfoQ 作者【YashanDB】的原创文章。
原文链接:【http://xie.infoq.cn/article/7e3ff12404baf6f2b998e03f4】。文章转载请联系作者。
评论