MYSQL数据表损坏的原因分析和修复方法小结(推荐)

MYSQL数据表损坏的原因分析和修复方法小结,碰到的朋友可以参考,下面整理一些比较全,希望对大家有所帮助。

1.表损坏的原因分析
以下原因是导致mysql 表毁坏的常见原因:
1、 服务器突然断电导致数据文件损坏。
2、 强制关机,没有先关闭mysql 服务。
3、 mysqld 进程在写表时被杀掉。
4、 使用myisamchk 的同时,mysqld 也在操作表。
5、 磁盘故障。
6、 服务器死机。
7、 mysql 本身的bug 。

2.表损坏的症状
一个损坏的表的典型症状如下:
1 、当在从表中选择数据之时,你得到如下错误:
Incorrect key file for table: ‘…’. Try to repair it
2 、查询不能在表中找到行或返回不完全的数据。
3 、Error: Table ‘p’ is marked as crashed and should be repaired 。
4 、打开表失败: Can’t open file: ‘×××.MYI’ (errno: 145) 。
5 、
3.预防 MySQL 表损坏
可以采用以下手段预防mysql 表损坏:
1 、定期使用myisamchk 检查MyISAM 表(注意要关闭mysqld ),推荐使用check table 来检查表(不用关闭mysqld )。
2 、在做过大量的更新或删除操作后,推荐使用OPTIMIZE TABLE 来优化表,这样既减少了文件碎片,又减少了表损坏的概率。
3 、关闭服务器前,先关闭mysqld (正常关闭服务,不要使用kill -9 来杀进程)。
4 、使用ups 电源,避免出现突然断电的情况。
5 、使用最新的稳定发布版mysql ,减少mysql 本身的bug 导致表损坏。
6 、对于InnoDB 引擎,你可以使用innodb_tablespace_monitor 来检查表空间文件内文件空间管理的完整性。
7 、对磁盘做raid ,减少磁盘出错并提高性能。
8 、数据库服务器最好只跑mysqld 和必要的其他服务,不要跑其他业务服务,这样减少死机导致表损坏的可能。
9 、不怕万一,只怕意外,平时做好备份是预防表损坏的有效手段。
4.MySQL 表损坏的修复
MyISAM 表可以采用以下步骤进行修复 :
1、 使用 reapair table 或myisamchk 来修复。
2、 如果上面的方法修复无效,采用备份恢复表。
具体可以参考如下做法:
阶段1 :检查你的表
如果你有很多时间,运行myisamchk *.MYI 或myisamchk -e *.MYI 。使用-s (沉默)选项禁止不必要的信息。
如果mysqld 服务器处于宕机状态,应使用–update-state 选项来告诉myisamchk 将表标记为’ 检查过的’ 。
你必须只修复那些myisamchk 报告有错误的表。对这样的表,继续到阶段2 。
如果在检查时,你得到奇怪的错误( 例如out of memory 错误) ,或如果myisamchk 崩溃,到阶段3 。
阶段2 :简单安全的修复
注释:如果想更快地进行修复,当运行myisamchk 时,你应将sort_buffer_size 和Key_buffer_size 变量的值设置为可用内存的大约25% 。
首先,试试myisamchk -r -q tbl_name(-r -q 意味着“ 快速恢复模式”) 。这将试图不接触数据文件来修复索引文件。如果数据文件包含它应有的一切内容和指向数据文件内正确地点的删除连接,这应该管用并且表可被修复。开始修复下一张表。否则,执行下列过程:
在继续前对数据文件进行备份。
使用myisamchk -r tbl_name(-r 意味着“ 恢复模式”) 。这将从数据文件中删除不正确的记录和已被删除的记录并重建索引文件。
如果前面的步骤失败,使用myisamchk –safe-recover tbl_name 。安全恢复模式使用一个老的恢复方法,处理常规恢复模式不行的少数情况( 但是更慢) 。
如果在修复时,你得到奇怪的错误( 例如out of memory 错误) ,或如果myisamchk 崩溃,到阶段3 。
阶段3 :困难的修复
只有在索引文件的第一个16K 块被破坏,或包含不正确的信息,或如果索引文件丢失,你才应该到这个阶段。在这种情况下,需要创建一个新的索引文件。按如下步骤操做:
把数据文件移到安全的地方。
使用表描述文件创建新的( 空) 数据文件和索引文件:
代码如下:
shell> mysql db_name
mysql> SET AUTOCOMMIT=1;
mysql> TRUNCATE TABLE tbl_name;
mysql> quit

如果你的MySQL 版本没有TRUNCATE TABLE ,则使用DELETE FROM tbl_name 。
将老的数据文件拷贝到新创建的数据文件之中。(不要只是将老文件移回新文件之中;你要保留一个副本以防某些东西出错。)
回到阶段2 。现在myisamchk -r -q 应该工作了。(这不应该是一个无限循环)。
你还可以使用REPAIR TABLE tbl_name USE_FRM ,将自动执行整个程序。
阶段4 :非常困难的修复
只有.frm 描述文件也破坏了,你才应该到达这个阶段。这应该从未发生过,因为在表被创建以后,描述文件就不再改变了。
从一个备份恢复描述文件然后回到阶段3 。你也可以恢复索引文件然后回到阶段2 。对后者,你应该用myisamchk -r 启动。
如果你没有进行备份但是确切地知道表是怎样创建的,在另一个数据库中创建表的一个拷贝。删除新的数据文件,然后从其他数据库将描述文件和索引文件移到破坏的数据库中。这样提供了新的描述和索引文件,但是让.MYD 数据文件独自留下来了。回到阶段2 并且尝试重建索引文件。
InnoDB 表可以采用下面的方法修复:
如果数据库页被破坏,你可能想要用SELECT INTO OUTFILE 从从数据库转储你的表,通常以这种方法获取的大多数数据是完好的。即使这样,损坏可能导致SELECT * FROM tbl_name 或者InnoDB 后台操作崩溃或断言,或者甚至使得InnoDB 前滚恢复崩溃。 尽管如此,你可以用它来强制InnoDB 存储引擎启动同时阻止后台操作运行,以便你能转储你的表。例如:你可以在重启服务器之前,在选项文件的[mysqld] 节添加如下的行:
[mysqld]innodb_force_recovery = 4innodb_force_recovery 被允许的非零值如下。一个更大的数字包含所有更小数字的预防措施。如果你能够用一个多数是4 的选项值来转储你的表,那么你是比较安全的,只有一些在损坏的单独页面上的数据会丢失。一个为6 的值更夸张,因为数据库页被留在一个陈旧的状态,这个状态反过来可以引发对B 树和其它数据库结构的更多破坏。
1 (SRV_FORCE_IGNORE_CORRUPT)
即使服务器检测到一个损坏的页,也让服务器运行着;试着让SELECT * FROM tbl_name 跳过损坏的索引记录和页,这样有助于转储表。
2 (SRV_FORCE_NO_BACKGROUND)
阻止主线程运行,如果崩溃可能在净化操作过程中发生,这将阻止它。
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)
不要在恢复连接中做日志前滚。
数据库不能另外地带着这些选项中被允许的选项来使用。作为一个安全措施,当innodb_force_recovery 被设置为大于0 的值时,InnoDB 阻止用户执行INSERT, UPDATE 或DELETE 操作.
即使强制恢复被使用,你也可以DROP 或CREATE 表。如果你知道一个给定的表正在导致回滚崩溃,你可以移除它。你也可以用这个来停止由失败的大宗导入或失败的ALTER TABLE 导致的失控回滚。你可以杀掉mysqld 进程,然后设置innodb_force_recovery 为3 ,使得数据库被挂起而不需要回滚,然后舍弃导致失控回滚的表。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/446356.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 20:57:58
下一篇 2025年11月7日 21:02:46

相关推荐

  • Golang并发处理数据库访问安全示例

    Go的database/sql包支持并发安全的数据库访问,通过连接池管理多个goroutine对同一sql.DB实例的安全使用。示例中10个goroutine并发执行查询,依赖连接池分配独立连接,确保操作隔离。需注意应用层竞态条件:共享map等非线程安全结构必须用sync.Mutex或sync.Ma…

    2025年12月16日
    000
  • 高并发场景下字符串校验:内存映射 vs. 数据库查询

    在高并发的 Go 服务器应用中,面对大量字符串校验需求,是选择将所有字符串加载到内存进行快速查找,还是每次请求都进行数据库查询?本文将分析两种方案的优缺点,并给出在不同场景下的选择建议。 在构建高并发的 Go 服务器应用时,经常会遇到需要对接收到的字符串进行校验的场景。例如,验证用户提交的 ID 是…

    2025年12月16日
    000
  • Go语言中切片Map的正确初始化与nil map运行时错误解析

    本文深入探讨Go语言中处理map切片时常见的assignment to entry in nil map运行时错误。我们将详细解释该错误产生的原因,并提供两种有效的解决方案:一是显式地初始化切片中的每个map元素,二是利用复合字面量进行简洁初始化。此外,文章还将介绍在Go中处理结构化数据时更推荐的s…

    2025年12月16日
    000
  • 优化字符串查找:内存映射 vs. 数据库查询

    在Go服务器应用开发中,经常会遇到需要对接收到的字符串进行验证的场景,例如验证字符串是否存在于数据库中。针对高并发的HTTP请求,如何高效地进行字符串查找是一个关键问题。通常有两种策略:一是每次请求都执行SQL查询;二是将所有字符串预先加载到内存中的Map,然后通过Map进行快速查找。选择哪种策略取…

    2025年12月16日
    000
  • Go语言中运行时常量与部署时配置的管理策略

    本文探讨了Go语言中如何优雅地管理在程序运行时保持不变,但在部署时可灵活配置的参数。针对const关键字的编译时限制,我们提出了一种推荐模式:通过在包的init函数中初始化未导出变量,并提供导出函数进行只读访问。这种方法既保证了配置的运行时不变性,又兼顾了部署环境的灵活性和代码的健壮性,有效避免了直…

    2025年12月16日
    000
  • Go语言中实现运行时可配置的“常量”:一种封装与初始化模式

    本教程探讨了在Go语言中,如何优雅地管理需要在程序运行时固定但部署时可配置的配置项。由于Go的const关键字仅支持编译时常量,文章提出了一种利用包级私有变量、init函数初始化和公共访问器函数相结合的封装模式,确保配置值在程序启动后不可变,同时保持部署灵活性。 在go语言开发中,我们经常遇到这样的…

    2025年12月16日
    000
  • Golang sync.Once单例模式实现实战

    使用 sync.Once 可确保初始化函数仅执行一次,实现线程安全的单例模式。其核心是通过 Do 方法包裹初始化逻辑,避免并发环境下重复创建实例,适用于数据库连接、配置加载等场景。典型结构包括全局实例变量、sync.Once 实例和 GetInstance 方法。实战中可用于懒加载数据库连接池,优势…

    2025年12月16日
    000
  • Go语言中实现部署时可配置的“常量”:基于init函数与封装的最佳实践

    在go语言的开发实践中,我们经常会遇到这样的需求:某些配置参数在程序运行期间应保持固定不变,但其具体数值需要在部署时根据环境进行调整。例如,数据库连接字符串、api密钥或服务端口等。go语言的const关键字看似能满足“常量”的需求,但其本质是编译时常量,这意味着const的值必须在编译时确定,无法…

    2025年12月16日
    000
  • Go中实现可配置的运行时常量:私有变量与公共访问器模式

    在Go语言中,const关键字要求编译时确定值,不适用于需要部署时配置但运行时保持不变的“常量”。本文将介绍一种推荐模式,通过在init函数中初始化包级私有变量,并提供公共的访问器(getter)函数,实现既能灵活配置又能在运行时保证值不可变的伪常量,从而有效管理应用程序配置。 Go语言中的常量与配…

    2025年12月16日
    000
  • Golang数据库CRUD操作项目实战

    答案:本文通过用户管理项目演示Go语言操作MySQL实现CRUD。首先搭建环境并创建数据库表,定义User结构体和数据库连接;接着编写CreateUser、GetUser、UpdateUser、DeleteUser函数完成增删改查;最后在main函数中依次调用测试各操作,验证流程正确性。强调错误处理…

    2025年12月16日
    000
  • Golang基准测试数据库查询性能优化

    答案:通过Go的基准测试优化数据库查询性能,需编写以Benchmark开头的测试函数,使用testing.B参数并调用b.ResetTimer()精准测量;合理配置sql.DB连接池的MaxOpenConns、MaxIdleConns和ConnMaxLifetime参数提升并发能力;优化SQL语句与…

    2025年12月16日
    000
  • Golang用户注册登录功能开发实战

    答案:使用Golang实现注册登录功能,通过项目分层设计、GORM操作数据库、bcrypt加密密码、JWT生成令牌、Gin框架处理路由与中间件,完成安全认证系统。 开发一个用户注册登录功能是大多数 Web 应用的基础需求。使用 Golang(Go语言)来实现这一功能,既能保证性能,又能保持代码简洁。…

    2025年12月16日
    000
  • Golang包初始化init函数使用注意事项

    init函数在程序启动时自动执行,用于包初始化。1. 执行顺序为:变量初始化→按文件字典序执行各文件init→同文件内按出现顺序执行;跨包顺序不可控。2. 避免耗时操作如网络请求,防止阻塞启动。3. 不依赖未解析的命令行参数或环境变量,应在main中处理。4. init本身线程安全,但若启动goro…

    2025年12月16日
    000
  • Golang抽象工厂模式使用与案例

    抽象工厂模式通过接口定义一组相关对象的创建方法,利用具体工厂实现不同产品族的构造,Go语言使用接口与结构体组合模拟该模式,适用于跨平台UI组件等需统一风格对象创建的场景。 在Go语言中,抽象工厂模式是一种创建型设计模式,它提供了一种方式来封装具有相同主题或业务逻辑的一组相关或相互依赖对象的创建过程,…

    2025年12月16日
    000
  • Go语言中函数别名与空白标识符_的限制及替代方案

    在Go语言中,由于空白标识符_具有特殊的语法含义,它不能被用作函数名或函数别名。本文将深入探讨_的特性,解释为何无法将其用于函数命名,并提供两种替代方案:通过import . “package”进行包级导入,以及将函数赋值给局部变量以实现调用上的简洁性。我们将分析这些方法的优…

    2025年12月16日
    000
  • Go语言中_作为函数别名的可行性探讨

    在Go语言中,将函数命名为或别名为 _(下划线)是不可行的。_在Go中是特殊的空白标识符,用于显式地忽略值、导入或变量,它不引入任何绑定,因此不能被调用。尽管不能直接使用 _,开发者可以通过将函数赋值给变量的方式,实现类似短别名的效果,但需权衡代码可读性。 理解Go语言中的空白标识符 (_) go语…

    2025年12月16日
    000
  • Go语言中函数别名与下划线标识符的限制

    在Go语言中,下划线(_)被定义为特殊用途的空白标识符,它不引入新的绑定,因此不能被用作函数名或函数别名来引用。尽管无法将函数直接命名或别名为_,但开发者可以通过将函数赋值给其他变量来创建其别名,从而实现简短的函数调用,尤其适用于减少包前缀的冗余。 理解Go语言中的空白标识符 (_) go语言中的下…

    2025年12月16日
    000
  • Golang包导入别名与冲突处理方法

    使用别名可简化长包名引用并提升可读性,如jsoniter “github.com/json-iterator/go”;2. 同名包导入时需用别名避免冲突,如myutils “projectB/utils”;3. 第三方库与标准库同名时应为第三方库设别名…

    2025年12月15日
    000
  • GolangWeb爬虫项目实战与数据存储

    Golang爬虫常用Colly和goquery,前者支持并发与反爬机制,后者便于HTML解析;2. 数据存储根据结构化需求选MySQL、PostgreSQL或MongoDB;3. 应对反爬需使用代理IP、设置User-Agent、处理验证码及动态加载内容。 Web爬虫,简单来说,就是模拟浏览器去抓取…

    2025年12月15日
    000
  • Golang并发爬虫实现与数据收集方法

    使用goroutine和channel实现并发爬虫,通过worker池控制协程数量,避免资源耗尽;结合信号量或缓冲channel限制并发请求,防止被封IP;利用goquery或xpath解析HTML,结构化数据后通过channel安全传递至存储协程;定义统一数据结构,集中写入数据库或文件;加入随机延…

    2025年12月15日
    000

发表回复

登录后才能评论
关注微信