mysql 5.7驱动_故障分析 | MySQL 无法启动,提示 missing……

作者:姚远

专注于 Oracle、MySQL 数据库多年,Oracle 10G 和 12C OCM,MySQL 5.6,5.7,8.0 OCP。现在鼎甲科技任顾问,为同事和客户提供数据库培训和技术支持服务。

本文来源:原创投稿 *爱可生开源社区出品,原创内容未经授权不得随意使用,转载请联系小编并注明来源。

故障描述

MySQL 数据库服务器的 CPU 和主板都换了,重新开机,发现 MySQL 无法启动!!!
提示: Ignoring the redo log due to missing MLOG_CHECKPOINT between the checkpoint  .... and ...
故障分析 这个问题出现在 MySQL 5.7 之后的版本,主要的原因是 MySQL 会在最新的 checkpoint 完成后都会在 redo log 写一个一字节的 MLOG_CHECKPOINT  标记,用来标记在此之前的 redo 都已 checkpoint 完成。如果处于任何原因没有找到这个标记,那么整个 redo log 文件都会被忽略。出现这个错误的话,最好是有备份进行恢复,如果没有做好备份,那只能采取非常规的启动方式,但可能造成数据丢失故障处理 移除当前使用的 redo log 文件,然后可以试着启动数据库,结果启动失败!
提示: [ERROR] InnoDB: Page [page id: space=0, page number=0] log sequence number 178377412422 is in the future! Current system log sequence number 165909011496.
这样的错误,这是因为 MySQL writer 线程按照配置的时间间隔以 page 为单位刷新 buffer 数据到磁盘。当数据刷新到磁盘的时候,新写入磁盘的 page 包含了较新的 LSN,此时系统 system 表空间头的 LSN 并没有同步更新,通常这是检查点线程的工作。在正常的崩溃恢复中,MySQL 可以借助 redo log 来进行前滚和回滚,但是此时 redo log 已经被我们删掉了,MySQL 无法进行恢复操作。此时,我们设置 innodb_force_recovery=3 来强制启动 MySQL,仍然启动不成功,改成 4 后启动了! 再使用 mysqldump 导出备份,结果噩梦又降临了!MySQL 又 crash 了。
提示: InnDB: Failed to find tablespace for table......
设置参数 innodb_force_recovery=5,数据库仍然启动失败,再设置成 6,启动成功!用 sqldump 顺利把数据备份出来了! 再初始化数据库,把刚刚备份的数据库导入,数据库恢复成功完成! 参数说明 这里的关键是设置 innodb_force_recovery 参数,对应这个参数的说明如下: 1. SRV_FORCE_IGNORE_CORRUPT:忽略检查到的 corrupt 页; 2. SRV_FORCE_NO_BACKGROUND:阻止主线程的运行,如主线程需要执行 full purge 操作,会导致 crash; 3. SRV_FORCE_NO_TRX_UNDO:不执行事务回滚操作; 4. SRV_FORCE_NO_IBUF_MERGE:不执行插入缓冲的合并操作; 5. SRV_FORCE_NO_UNDO_LOG_SCAN:不查看重做日志,InnoDB 存储引擎会将未提交的事务视为已提交;

6. SRV_FORCE_NO_LOG_REDO:不执行前滚的操作。


关于爱可生

上海爱可生信息技术股份有限公司是国内开源数据库解决方案领导者、工业互联网高维数据应用创新者。爱可生为产业互联网创新应用提供高性价比、快速落地实现的多数据库管理平台、分布式数据库系统、数据库容器云平台、多地多中心跨云容灾等解决方案。

在工业互联网相关垂直行业,深入分析数据价值,构建数据中台和业务中台的基础软件PaaS平台,用数据技术驱动企业高质量增长。公司产品已被广泛应用于各行业,累计用户超过400家,其中包括工商银行、中国人寿、中国太保、国家电网、上汽集团、中国移动、华为等30多家世界500强企业。

d8f0ab53ee349a5392f1bf90535981e0.png

59fce8a5473813a2fcd36f46dfd927b6.png

点击此处“阅读全文”,了解更多 d125f08bef20603543fdbfce29026963.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL 5.7中,没有内置的ROW_NUMBER()函数来实现行号的功能。但是,你可以使用变量来模拟ROW_NUMBER()函数的行为。下面是一个示例SQL语句,可以在MySQL 5.7中实现类似ROW_NUMBER()的功能: ``` SELECT @rownum := @rownum + 1 AS rownum, b.id, b.update_time, IF(@mno = b.id OR (@mno IS NULL AND b.id IS NULL), @rank := @rank + 1, @rank := 1) AS row_number FROM (SELECT * FROM table ORDER BY id, update_time DESC) b, (SELECT @rownum := 0, @rank := 0, @mno := NULL) r WHERE row_number = 1; ``` 这个查询语句使用了变量`@rownum`和`@rank`来模拟ROW_NUMBER()函数的行为。首先,我们通过子查询将变量初始化为0。然后,在外部查询中,我们使用`@rownum`变量来计算行号,并使用`@rank`变量来计算每个id的排名。最后,我们通过WHERE子句选择排名为1的行。 请注意,这只是一种在MySQL 5.7中模拟ROW_NUMBER()函数的方法,并不是官方支持的方法。如果你需要更高级的窗口函数功能,建议升级到MySQL 8.0或更高版本。 #### 引用[.reference_title] - *1* *2* *3* [mysql5.7实现ROW_NUMBER() OVER(PARTITION BY XXX)功能查询](https://blog.csdn.net/shen_xbo/article/details/120451733)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值