mysql故障分析——关闭binlog

最近开始维护一个运行多年的私有化项目。
项目使用docker部署,mysql、应用等都在一个镜像中,mysql数据挂载在物理机上。mysql属于单机,开启了binlog,因为数据比较重要,经年未做清理,导致binlog文件过大直接爆盘。我们做了以下步骤关闭binlog:

# 进入容器
vi /etc/mysql/my.cnf

# 将以下2行注释,关闭binlog
# log-bin=mysql-bin
# binlog_format=mixed
# 删除binlog日志文件
rm -rf /data/mysql/mysql-bin.*

在关闭binlog后,重启容器,发现mysql无法启动,查看日志显示

Can't connect to local MySQL server through socket '/run/mysqld/mysqld.sock' (111 'connection refused')

这时,我们将/run/mysqld/mysqld.sock文件删除,mysqld还是无法启动。我们将现有容器删除,重新部署容器,因为这时的镜像是未关闭binlog的,所以无法正常启动,并且会显示以下错误

Can't connect to local MySQL server through socket '/run/mysqld/mysqld.sock' (2)

然后进入容器,将binlog再次关闭,这时发现mysql未成功启动原因改变了

[ERROR] Found 1 prepared transactions! It means that mysqld was not shut down properly last time and critical recovery information (last binlog or tc.log file) was manually deleted after a crash. You have to start mysqld with --tc-heuristic-recover switch to commit or rollback pending transactions.

这个问题原因是,我们在关闭binlog时,并没有关闭mysql进程,导致关闭binlog的过程中还有事务进行,解决办法如下:

# 先通过  --tc-heuristic-recover=ROLLBACK 将事物回滚
/usr/bin/mysqld --basedir=/usr --datadir=/data/mysql --plugin-dir=/usr/lib/mysql/plugin --user=root --log-error=/data/mysql/mysqld.err --pid-file=/data/mysql/mysql.pid --socket=/run/mysqld/mysqld.sock --port=3306 --tc-heuristic-recover=ROLLBACK

# 在正常启动mysql
/usr/bin/mysqld --basedir=/usr --datadir=/data/mysql --plugin-dir=/usr/lib/mysql/plugin --user=root --log-error=/data/mysql/mysqld.err --pid-file=/data/mysql/mysql.pid --socket=/run/mysqld/mysqld.sock --port=3306

最后,在关闭binlog,删除binlog日志文件时,一定要记得先关闭进程。或者直接使用mysql命令 reset master; 直接清除binlog

你可能感兴趣的:(问题记录)