Linux 定时检测 MySQL 数据库是否宕机并自动重启

我们建站初期都会选择一台小内存的 VPS 服务器,这样降低建站初期的成本,再说初期访问量很小没有必要使用高配服务器,但是使用过程中不知道是不是内存不够的原因,MySQL 数据库服务…

我们建站初期都会选择一台小内存的 VPS 服务器,这样降低建站初期的成本,再说初期访问量很小没有必要使用高配服务器,但是使用过程中不知道是不是内存不够的原因,MySQL 数据库服务总是会自动停止,就是说数据库都宕机了。那么有没有什么办法在 Linux 上定时检测 MySQL 服务是否宕机,并自动重启服务 Linux 上定时检测 MySQL 服务是否宕机,并自动重启服务呢?本文分享个基于 Shell 脚本和 crontab 命令的定时检测 MySQL 服务是否宕机,并自动重启服务的方案,如果你也遇到了这种问题,可是尝试用这种解决办法。

一、检测 MySQL 服务脚本

MySQL 自动重启的 Shell 脚本非常简单,整个逻辑就是检测是否有 MySQL 的进程,如果没有就重启并记录到日志文件中:

pgrepmysqld&>/dev/nullif[$?-gt0]thenlnmprestartecho"MySQLstoppedattime:`date`">>/root/log/mysql_listen.logfi二、定时任务

定时检测的功能就是通过 crontab 实现的,具体的介绍可以参考:《Linux 利用 crontab 实现定时任务格式与用法简介》

例如我这里设置的是每 5 分钟检查一次 MySQL 服务:

*/5****/root/mysql.sh>/dev/null2>&1&三、更多脚本

除了检测 MySQL 服务外,相应的还可以检测 PHP 服务、Nginx 服务等,在脚本上略微改动下就好了:

pgrepmysqld&>/dev/nullif[$?-gt0]thenlnmprestartecho"MySQLstoppedattime:`date`">>/root/log/mysql_listen.logfipgrepnginx&>/dev/nullif[$?-gt0]thenlnmprestartecho"Nginxstoppedattime:`date`">>/root/log/mysql_listen.logfipgrepphp-fpm&>/dev/nullif[$?-gt0]thenlnmprestartecho"Phpstoppedattime:`date`">>/root/log/mysql_listen.logfi

这样再也不要担心数据库莫名其妙宕机了,使用上述代码 Linux 会定时检测 MySQL 数据库服务是否宕机,如果出现数据库宕机则自动重启数据库服务。

产品猿社区致力收录更多优质的商业产品,给服务商以及软件采购客户提供更多优质的软件产品,帮助开发者变现来实现多方共赢;

日常运营的过程中我们难免会遇到各种版权纠纷等问题,如果您在社区内发现有您的产品未经您授权而被用户提供下载或使用,您可按照我们投诉流程处理,点我投诉

本文来自用户发布投稿,不代表产品猿立场 ;若对此文有疑问或内容有严重错误,可联系平台客服反馈;

部分产品是用户投稿,可能本文没有提供官方下下载地址或教程,若您看到的内容没有下载入口,您可以在我们产品园商城搜索看开发者是否有发布商品;若您是开发者,也诚邀您入驻商城平台发布的产品,地址:点我进入

如若转载,请注明出处:https://www.chanpinyuan.cn/40851.html;
(0)
上一篇 2023年4月5日 下午4:17
下一篇 2023年4月7日 下午4:17

相关推荐

发表回复

登录后才能评论
分享本页
返回顶部