• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

实战:mysql检查物理磁盘中的二进制日志文件是否有丢失_MySQL

mysql 搞代码 4年前 (2022-01-09) 25次浏览 已收录 0个评论

场景:有时候因为磁盘损坏或人为原因错误删除了磁盘中的二进制文件,导致mysql中的show binary logs记录和实际的物理磁盘中的二进制文件不匹配

#binlogdiff.sh
#!/bin/sh
#[email protected]
#作用:mysql中show binary logs记录的二进制日志文件和实际的物理文件比较,检查
#磁盘中对应的二进制日志文件是否有丢失

source /usr/local/mysql/scripts/mysql_env.ini
binlog_init=tmpinit.`date +%Y%m%d%H%M%S`.txt
binlog_midd=tmpmidd.`date +%Y%m%d%H%M%S`.txt #mysql中show binary logs记录的日志文件
binlog_res=tmpres.`date +%Y%m%d%H%M%S`.txt #binlog物理磁盘路径中的日志文件

my_cnf=/usr/local/mysql/my.cnf #mysql的配置文件
log_bin_path=`grep -i “^log-bin” $my_cnf |cut -d = -f 2`
log_bin=`dirname $log_bin_path`

#lookup binlog records in mysql
mysql -h${MYSQL_HOST} -u${MYSQL_USER} -p${MYSQL_PASS} -e”show binary logs;” >${binlog_init}
cat ${binlog_init} | cut -f 1 |cut -d . -f 2 |grep -i '^[0-9]' |sort -n >${binlog_midd}

#lookup binlog records in disk
ls -t ${log_bin}| grep '^mysql-bin' |cut -d . -f 2 |grep -i '^[0-9]' |sort -n >${binlog_res}

diff -c ${binlog_midd} $binlog_res

#clean t本文来源gao($daima.com搞@代@#码(网emp file
rm -rf ${binlog_init}
rm -rf ${binlog_midd}
rm -rf ${binlog_res}


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:实战:mysql检查物理磁盘中的二进制日志文件是否有丢失_MySQL

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址