宝塔面板的mysql经常自动停止怎么办?解决方法看这里

[复制链接]
查看: 551|回复: 0

29

主题

29

帖子

99

积分

注册会员

Rank: 2

积分
99
发表于 2020-2-14 09:47:00 | 显示全部楼层 |阅读模式
最近使用宝塔面板经常遇到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_sizeinnodb_buffer_pool_size=50M
出现数据库经常停止,可以参照下面解决方案:

解决方法一:

在宝塔面板后台-软件商店,安装宝塔面板【linux工具箱】,添加设置SWAP大小,根据你的实际内存进行调整,swap是Linux下的虚拟内存,设置适当的swap可增加服务器稳定性,建议swap容量在真实内存容量的1.5倍左右,若您的服务器内存大于4GB,可设1-2GB的固定值,swap文件默认保存在/www/swap,设置前请确保磁盘空间够用。

1.gif

解决方法二:

根据你的实际内存进行mysql优化

1.jpg

解决方法三:

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

1.jpg
  1. pgrep -x mysqld &> /dev/null
  2. if [ $? -ne 0 ];then
  3.         bash /www/server/panel/script/rememory.sh   
  4.         /etc/init.d/mysqld start      
  5. fi
复制代码
解决方法四:

这个方法简单粗暴,适合土豪站长,直接增加服务器内存或使用云数据库,把数据库分离出去。如果你遇到mysql问题或有更好的解决方法欢迎跟贴一起探讨。

腾讯云
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

精彩图文



在线客服(工作时间:9:00-22:00)
400-600-6565

内容导航

微信客服

Copyright   ©2015-2019  云服务器社区  Powered by©Discuz!  技术支持:尊托网络     ( 湘ICP备15009499号-1 )