本文内容来自YashanDB官网,原文内容请见www.yashandb.com/newsinfo/73…
在内存使用接近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替换成数据库实例用户