宝塔面板MySQL自动关闭的解决方法

宝塔面板是一款简单好用的Linux/Windows服务器运维管理面板,被外贸独立站建站用户广泛用于配置服务器环境,包括:LAMP/LNMP、网站、数据库、FTP、SSL等,这样可以通过Web端轻松管理服务器。

在外贸建站过程中,有使用宝塔面板运维独立服务器的用户反馈会遇到出现“Error establishing a database connection数据库连接错误,导致网站无法正常访问的情况。这种错误主要出现在腾讯云等一些轻量型服务器上,因为某些原因(比如:恶意攻击、服务器配置较低等)导致某个时间节点出现了内存不足或者CPU占用100%,服务器负载过高而导致MySQL数据库服务意外停止。经过WPPOP技术人员的耐心排查,我们发现,其服务器环境中的 MySQL 服务自动关闭,停止运行了。可在宝塔面板的【 软件商店 – 已安装 】的应用分类列表中查看 MySQL 运行状态。

解决方法 1:手动重启 MySQL 服务

直接在宝塔面板的【 软件商店 – 已安装 】的应用分类列表中找到 MySQL 软件,点击右侧对应的 设置 项,在弹出操作窗口中,点击 启动 ,重新打开 MySQL 服务。

解决方法 2:安装宝塔面板里的 Linux工具箱

在宝塔面板的【 应用商店 】中搜索“Linux工具箱”,点击 安装 按钮,安装好 Linux工具箱 后,在 Linux工具箱 的弹窗设置中,找到 Swap/虚拟内存 设置项,根据使用的服务器配置来进行虚拟内存的设置。

不管网站使用的服务器内存多大,都建议添加 Swap。

  • swap是Linux下的虚拟内存,设置适当的swap可增加服务器稳定性
  • 建议swap容量在真实内存容量的1.5倍左右,若您的服务器内存大于4GB,可设1-2GB的固定值
  • swap文件默认保存在/www/swap,设置前请确保磁盘空间够用
  • 若您不需要swap,请将容量设为0
  • OVZ虚拟架构机器不可用此功能

Swap/虚拟内存 推荐值

2G 和 2G 以下内存的服务器,建议设置成和物理内存相同容量的 SWAP;

2G 以上的内存的服务器,建议设置为 2G。如果网站程序特别耗内存,2G 内存以上的 Swap 也可以设置与内存相同容量。

解决方法 3:添加 MySQL 服务自动重启的 Shell 脚本

在宝塔面板中的计划任务中,添加 MySQL 数据库自动重启的 shell 脚本,定时自动重启运行中的 MySQL 数据库,缓减 MySQL 数据库的压力。

pgrep -x mysqld &> /dev/null
if [ $? -ne 0 ];then
        bash /www/server/panel/script/rememory.sh   
        /etc/init.d/mysqld start      
fi

把上面的 Shell 脚本,添加到宝塔的计划任务中。

MySQL进程守护执行周期不建议设置的过小,可以是1小时30分钟;如果该脚本的执行周期时间设置的过短,当你在网站后台更新发布文章或者升级网站程序时,可能会造成不必要的错误!

如果 MySQL 数据库已经停止,通过添加下面的 shell 脚本自动检测 MySQL 数据库是否为停止状态,如果检测到 MySQL 数据库停止,则自动重启。相关 shell 脚本代码如下:

#!/bin/bash PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin export PATH pgrep -x mysqld /dev/null if [ $? -ne 0 ] echo At time:$(date) :MySQL is stop . /var/log/mysql_messages service mysqld start fi

MySQL监控重启执行周期,可以设置为1分钟检测一次,也就当你 MySQL 数据库停止后,1分钟内就会自动重启,确保网站可以正常访问!

By 行政