返回顶部
首页 > 资讯 > 数据库 >MYSQL Truncate 引发数据表损坏案例分析
  • 554
分享到

MYSQL Truncate 引发数据表损坏案例分析

2024-04-02 19:04:59 554人浏览 安东尼
摘要

最近发布到市场的版本频繁出现数据库表损坏的情况,具体的现象是select表提示表不存在,但是查看data文件,对应表的ibd和frm文件都在。 通过对多个故障的统计,找到几个频繁出现损坏的表,在分

最近发布到市场的版本频繁出现数据库表损坏的情况,具体的现象是select表提示表不存在,但是查看data文件,对应表的ibd和frm文件都在。

通过对多个故障的统计,找到几个频繁出现损坏的表,在分析过程中,发现这些数据表都使用了truncate清除数据,所以怀疑是truncate操作的问题。

设计如下过程来验证这个分析结果:

1、 创建存储过程如下,对一张表模拟频繁调用TRUNCATE

DROP PROCEDURE IF EXISTS prcTest5;
CREATE PROCEDURE prcTest5(in ic int)
BEGIN
declare i int;
set i=0;
while(i<5) DO
truncate table alarmtest5;
insert into alarmtest5 select * from port limit ic;
set i=i+1;
END WHILE;

END;

2、 使用SOAP UI创建压力测试用例
MYSQL Truncate 引发数据表损坏案例分析

发起的线程为5
测试时间间隔0.5s

3、 使用bat脚本周期taskkill Mysqld进程并重新启动

@echo off
:loop
echo kill
taskkill /f /im mysqld.exe
echo RegMysqlServer
call RegMysqlServer.bat
call:sleep 20000
::调用方法call:sleep [毫秒] (1秒=1000毫秒)

Goto loop

:sleep
set tmp="%temp%\tmp.vbs"
echo wscript.sleep %1>%tmp%&%tmp%&del %tmp%
goto :eof

4、 启动测试,持续5-10分钟,关闭测试,打开数据库,发现数据表损坏。

select * from alarmtest5;

提示表不存在,实际到data目录下看,frm和ibd文件都在。

5、 怀疑是多线程导致问题,将线程数降为1,运行5-10分钟后,依然出现数据库表损坏现象。
6、 将存储过程修改为使用DELETE语句,测试线程数5,没有出现数据库表损坏的情况。

DROP PROCEDURE IF EXISTS prcTest4;
CREATE PROCEDURE prcTest4(in ic int)
BEGIN
declare i int;
set i=0;
while(i<5) DO
delete from alarmtest4;
insert into alarmtest4 select * from port limit ic;
set i=i+1;
END WHILE;

END;
7、查看MySQL官方文档,When a table is truncated, it is dropped and re-created in a new .ibd file,结合自测的情况,怀疑是我们每张表使用一个ibd文件,TRUNCATE表是重建ibd文件过程中mysql进程中断,导致ibd文件损坏。
MYSQL Truncate 引发数据表损坏案例分析

7、 重新创建一个数据库,将innodb_file_per_table = 1参数去掉,所有表共享一个ibd文件。
重复上面的测试,运行15分钟没有出现数据库表损坏的情况。

分析结论

innodb_file_per_table = 1,使用TRUNCATE会重新创建ibd文件,如果这个过程中mysqld进程意外中断,有很大概率出现数据库表损坏的现象。

您可能感兴趣的文档:

--结束END--

本文标题: MYSQL Truncate 引发数据表损坏案例分析

本文链接: https://lsjlt.com/news/45564.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MYSQL Truncate 引发数据表损坏案例分析
    最近发布到市场的版本频繁出现数据库表损坏的情况,具体的现象是select表提示表不存在,但是查看data文件,对应表的ibd和frm文件都在。 通过对多个故障的统计,找到几个频繁出现损坏的表,在分...
    99+
    2024-04-02
  • MySQL数据库表损坏如何解决
    本篇文章为大家展示了MySQL数据库表损坏如何解决,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。MySQL表损坏解决办法 过程处理: 1、早上登...
    99+
    2024-04-02
  • MySQL数据库表损坏后如何修复
    这篇文章主要为大家展示了“MySQL数据库表损坏后如何修复”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“MySQL数据库表损坏后如何修复”这篇文章吧。1.MyI...
    99+
    2024-04-02
  • MySQL中索引的案例分析
    小编给大家分享一下MySQL中索引的案例分析,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!1. 索引种类在 MySQL 中,从索引的逻辑或者说字段特性来区分,索引大致分为以下几个种类:普通索引...
    99+
    2024-04-02
  • MySQL多表查询案例分析
    本篇内容介绍了“MySQL多表查询案例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!多表查询案列说明笛卡尔积的理解select...
    99+
    2023-06-29
  • mysql两表查询的案例分析
    小编给大家分享一下mysql两表查询的案例分析,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!mysql两表查询的方法:1、使用“select 字段列表 from 表1,表2 [whe...
    99+
    2024-04-02
  • mysql多表查询的案例分析
    小编给大家分享一下mysql多表查询的案例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!mysql多表查询一般用交叉连接、内...
    99+
    2024-04-02
  • MySQL数据透视表的示例分析
    这篇文章主要为大家展示了“MySQL数据透视表的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“MySQL数据透视表的示例分析”这篇文章吧。我有一张这样的...
    99+
    2024-04-02
  • MySQL数据库HA方案的示例分析
    这篇文章主要为大家展示了“MySQL数据库HA方案的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“MySQL数据库HA方案的示例分析”这篇文章吧。一、&...
    99+
    2024-04-02
  • mysql多个联合索引的案例分析
    小编给大家分享一下mysql多个联合索引的案例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!MySQL中索引规则:1、需要加...
    99+
    2024-04-02
  • mysql数据库索引应用的示例分析
    mysql数据库索引应用的示例分析,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一、索引的概念    ...
    99+
    2024-04-02
  • MySQL数据分析存储引擎示例讲解
    目录1.引入案例2.查看系统默认的存储引擎和默认字符集3.常见的存储引擎1)MyISAM:不支持事务。(张马虎)MyISAM的优缺点:2)InnoDB:支持事务。(李小心)InnoD...
    99+
    2024-04-02
  • 数据分析案例-电影数据可视化分析
    数据介绍 数据为2011-2021电影数据 可视化分析 首先导入本次项目需要的包和数据 import pandas as pdimport numpy as npimport matplotlib.pyplot as pltimport ...
    99+
    2023-10-03
    python 数据分析
  • 记一次将测试数据库的数据清空,执行truncate引发ORA-02266的问题分析
    原文: https://www.enmotech.com/web/detail/1/760/1.html   (复制链接,打开浏览器即可查看)  文章转载...
    99+
    2024-04-02
  • mysql正则表达式的案例分析
    小编给大家分享一下mysql正则表达式的案例分析,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!MySQL支持基于正则表达式和REGEXP运算符的另一种模式匹配操作。1.它提供了强大而灵活的模式...
    99+
    2024-04-02
  • Docker案例分析:搭建MySQL数据库服务
    目录1 创建配置和数据目录3 从镜像内复制配置文件到宿主机4 创建并运行mysql容器5 宿主机连接数据库5.1 终端命令连接5.2 数据库工具连接6 查看mysql日志使用官方的m...
    99+
    2024-04-02
  • SQL数据库的案例分析
    小编给大家分享一下SQL数据库的案例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!数据表PRAGMA foreign_keys =&nbs...
    99+
    2023-06-22
  • Python数据分析案例合集
    案例一、利用税务数据分析美国人群收入情况 ...
    99+
    2023-01-31
    合集 案例 数据
  • Python的xpath数据解析案例分析
    这篇“Python的xpath数据解析案例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python的xpath数据解析...
    99+
    2023-06-29
  • MySQL更改数据库数据存储目录的案例分析
    小编给大家分享一下MySQL更改数据库数据存储目录的案例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!方法如下:1:确认My...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作