最近小编使用宝塔经常遇到mysql自动停止,好多读者发讯息给小编说网站打不开,小编于是查看了一下服务器mysql的日志,发现mysql出错时报【InnoDB: Fatal error: cannot allocate memory for the buffer pool】
Innodb 储存引擎的快取机制和 MyISAM 的最大区别就在于 Innodb 不仅仅快取索引,同时还会快取实际的资料。所以,完全相同的数据库,使用 Innodb 储存引擎可以使用更多的内存来快取数据库相关的资讯,当然前提是要有足够的实体内存。innodb_buffer_pool_size 引数用来设定 Innodb 最主要的 Buffer(Innodb_Buffer_Pool)的大小,也 就是快取使用者表及索引资料的最主要快取空间,对 Innodb 整体效能影响也最大。这个引数设定成内存的50%-80%,当然具体要结合实际情况而定,考虑别的储存引擎占用的内存,考虑服务器是不是还提供其他服务等等…看来,我的机器之所以宕掉的原因是,系统预设的内存:
default innodb_buffer_pool_size
innodb_buffer_pool_size=50M
出现数据库经常停止可以参照下面解决方案:
解决方法一:
安装宝塔面板【linux工具箱】


新增设定SWAP大小,根据你的实际内存进行调整,swap是Linux下的虚拟内存,设定适当的swap可增加服务器稳定性,建议swap容量在真实内存容量的1.5倍左右,若您的服务器内存大于4GB,可设1-2GB的固定值,swap档案预设储存在/www/swap,设定前请确保磁盘空间够用。
解决方法二:
根据你的实际内存进行mysql优化

解决方法三:
登陆宝塔后台-计划任务-新增Mysql守护,执行周期,可选择多长时间执行一次,比如10分钟监控执行一次,具体的周期请站长根据自己服务器实际情况来设定。

pgrep -x mysqld &> /dev/null
if [ $? -ne 0 ];then
bash /www/server/panel/script/rememory.sh
/etc/init.d/mysqld start
fi
解决方法四:
这个方法简单粗暴,适合土豪站长,直接增加服务器内存或使用云数据库,把数据库分离出去。
如果你遇到mysql问题或有更好的解决方法欢迎投稿给小编,我们和你一起探讨学习。小编投稿邮箱:[email protected]





























