解决由于日志占满空间导致的MySQL无法启动问题

今天收到监控邮件说博客访问失败。打开页面一看,硕大的502 Bad Gateway,ping了一下VPS发现是通的,SSH连接上去看了下Nginx日志发现没问题,重启lnmp的时候发现Mysql起不来,问题源头基本找到。

tail /usr/local/mysql/var/slyar.err

看了一下Mysql的错误日志,意外状况出现。。。

Disk is full writing './mysql-bin.~rec~' (Errcode: 28). Waiting for someone to free space... (Expect up to 60 secs delay for server to continue after freeing disk space)

神奇的情况,居然是因为磁盘满了无法写入日志导致Mysql起不来

root@slyar# df
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/sda1 3016688 2877540 0 100% /

果然啊,/var目录爆了

root@slyar:/usr/local/mysql/var# ll --block-size=MB
total 504MB
-rw-rw---- 1 mysql mysql 26MB Jul 23 2012 mysql-bin.000011
-rw-rw---- 1 mysql mysql 5MB Jul 26 2012 mysql-bin.000012
-rw-rw---- 1 mysql mysql 27MB Aug 8 2012 mysql-bin.000013
-rw-rw---- 1 mysql mysql 43MB Aug 23 2012 mysql-bin.000014
-rw-rw---- 1 mysql mysql 270MB Feb 9 17:05 mysql-bin.000020
-rw-rw---- 1 mysql mysql 115MB Apr 19 12:27 mysql-bin.000021
-rw-rw---- 1 mysql mysql 1MB Feb 10 12:07 mysql-bin.index
-rw-rw---- 1 mysql mysql 0MB Apr 19 12:34 mysql-bin.~rec~

基本上就是被这些玩意占满了,查了一下Mysql手册发现这些东西也没啥用,直接删除(此操作最好在Mysql服务停止时进行,因为当前日志使用的话无法删除,而且有可能导致一些其它问题,不过用mysql>reset master命令可以直接清空日志)

root@slyar:/usr/local/mysql/var# rm -f mysql-bin.*

为了防止再次出现此类状况,直接关闭Mysql的log-bin日志功能

vim /etc/my.cnf

找到:
log-bin=mysql-bin
binlog_format=mixed

在前面加上#注释掉,:wq保存退出

最后

/etc/init.d/mysql restart

启动Mysql服务,一切正常。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL 8.0 服务无法启动可能有多种原因,以下是一些可能的解决办法: 1. 检查MySQL配置文件:打开MySQL的配置文件(my.cnf或my.ini),确保配置正确。特别需要检查以下项:监听IP地址、端口号、日志文件路径等。如果有错误或缺失,进行相应的修正。 2. 检查MySQL日志文件:查看 MySQL 的错误日志文件,通常为 mysqld.log 或者 error.log,查找其中是否有任何错误信息。根据错误信息调查并解决。 3. 检查 MySQL 数据目录权限:MySQL 数据库目录需要具有适当的权限才能启动。确保 MySQL 数据目录及其子目录的所有者和组都正确,并且具有适当的读写权限。 4. 检查系统资源占用:如果服务器的内存、CPU 或磁盘空间不足,可能导致 MySQL 服务无法启动。使用系统监控工具检查资源使用情况,并确保足够的资源可用。 5. 检查 MySQL 安装文件完整性:如果 MySQL 安装文件损坏或缺失,可能会导致服务无法启动。重新下载或修复安装文件,并使用清洁的文件进行安装。 6. 检查是否有其他程序占用 MySQL 的端口:确保 MySQL 配置的端口没有被其他程序占用。可以使用命令行工具如 netstat 或 lsof 来查找端口占用情况,然后修改 MySQL 配置以使用未被占用的端口。 7. 重新安装 MySQL:如果上述方法无法解决问题,可以尝试重新安装 MySQL。首先卸载现有的 MySQL,然后再重新安装。确保按照官方文档提供的步骤进行操作。 以上是一些常见的解决办法,具体解决方法可能因具体情况而异。如果问题仍然存在,可能需要更详细的信息并参考 MySQL 官方文档或寻求专业的技术支持。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值