如何跳过校验MySQL 5.7 下有方法可以跳过崩溃恢复时的表空间校验过程嘛?查阅了资料,方法主要有两种:
1. 配置 innodb_force_recovery可以使 srv_force_recovery != 0 ,那么 validate = false,即可以跳过表空间校验。实际测试的时候设置 innodb_force_recovery =1,也就是强制恢复跳过坏页,就可以跳过校验,然后重启就是正常启动了。通过这种临时方式可以避免崩溃恢复后非常耗时的表空间校验过程,快速启动 MySQL,个人目前暂时未发现有什么隐患。2. 使用共享表空间替代独立表空间这样就不需要打开 N 个 ibd 文件了,只需要打开一个 ibdata 文件即可,大大节省了校验时间。自从听了姜老师讲过使用共享表空间替代独立表空间解决 drop 大表时性能抖动的原理后,感觉共享表空间在很多业务环境下,反而更有优势。
临时冒出另外一种解决想法,即用 GDB 调试崩溃恢复,通过临时修改 validate 变量值让 MySQL 跳过表空间验证过程,然后让 MySQL 正常关闭,重新启动就可以正常启动了。但是实际测试发现,如果以 debug 模式运行,确实可以临时修改 validate 变量,跳过表空间验证过程,但是 debug 模式下代码运行效率大打折扣,反而耗时更长。而以非 debug 模式运行,则无法修改 validate 变量,想法破灭。
打开电脑的“开始”菜单栏,找到“运行”,在运行框中直接输入:net start mysql。再点击确定按钮,如下图:2
等上图中cmd命令框中的显示完“mysql 服务正在启动”之后,再找到mysql的界面软件SQL yog打开,就可以直接进入了,如下图:
3
当你可以正常查询数据的时候就表示你的mysql数据库服务是正常运行的,也就是表示我们的启动是成功的。
END
通过cmd快速关闭mysql服务
我们这里还是讲通过cmd快速关闭mysql服务,不必麻烦的跑到电脑的服务中找出服务项手动关闭,打开电脑的“开始”菜单栏,找到“运行”,在运行框中直接输入:net stop mysql。再点击确定按钮,如下图:
注:MysqlServiceName 可以通过 net start,看看mysql的服务名。停止:net stop MysqlServiceName
启动:net start MysqlServiceName
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)