mysql8通过data文件恢复数据

2024-08-24 11:36
文章标签 数据 恢复 mysql8 data

本文主要是介绍mysql8通过data文件恢复数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景

云服务器中毒,导致mysql停止。只有data文件

备份mysql数据库文件

1、执行打包命令把data文件下载至本地。
zip -r dest.zip /opt/data/mysql
2、在本地虚拟机搭建相同版本的mysql数据库。

下载python脚本转换.ibd文件为sql文件

1、python转换地址https://github.com/ddcw/ibd2sql.git
2、下载python3
3、测试
python3 /opt/ibd2sql/main.py /opt/sfms@002defms/sys_user.ibd –sql > /opt/sys_usr_s.sql
“/opt/ibd2sql/main.py”为python脚本目录。
“/opt/sfms@002defms/sys_user.ibd”为备份的.ibd文件。
“sql” 为生成insert语句。
“ddl”为生成createtable语句。
“/opt/sys_usr_s.sql”为生成sql语句的目录
生成完后查看文件内容是否正确

编写shell脚本批量执行python命令

我的表有一百多张,不可能每张表都执行python 脚本的ddl和sql命令。
所以我在centos虚拟机上编写shell脚本批量执行。
前提是在centos虚拟机上安装python3及上传ibd2sql代码河相关.ibd文件
脚本如下

#!/bin/bash
#.ibd文件位置
dir="/opt/sfms@002defms"
tstrc="_c.sql"
tstrs="_s.sql"
path="/opt/bak/"
# 遍历当前目录下的所有文件
for file in $dir/*; do# 检查是否是文件if [ -f "$file" ]; thenfilePath="$file"fileName=$(echo $filePath | rev | cut -d "/" -f 1 | rev)fileNames=$(echo $fileName | rev |cut -d"." -f 2 | rev)echo "$path"$fileNames"$tstrc"python3 /opt/ibd2sql/main.py "$file"  --ddl > "$path"$fileNames"$tstrc"python3 /opt/ibd2sql/main.py "$file"  --sql > "$path"$fileNames"$tstrs"fi
done

注意给文件赋权限chomd +x file.sh
执行file.sh

编写批量执行sql文件python代码并执

生成的*_c.sql为建表语句。
生成的*_s.sql为insert语句。
如果在navicat执行sql文件会执行很多遍,所以我就写了一个python脚本批量执行多个sql文件。
代码如下:

import mysql.connector
import os # 连接到MySQL数据库
config = {'user': 'xx','password': 'wxx*','host': 'xxx','database': 'xx'
}
cnx = mysql.connector.connect(**config)
# 创建一个游标对象
cursor = cnx.cursor()# 获取文件夹路径
folder_path = '/usr/local'
# 存储所有文件内容的列表
file_contents = []# 遍历文件夹中的每个文件
for root, dirs, files in os.walk(folder_path):for file_name in files:file_path = os.path.join(root, file_name)# 打开文件并读取内容with open(file_path, 'r',encoding='utf-8') as file:content = file.read()file_contents.append(content)# 打印所有文件内容
for content in file_contents:print(content)cursor.execute(content)# 提交并关闭连接
cnx.commit()
cursor.close()
cnx.close()

在windows电脑就可以

结束

执行完sql后,新建备份,重装mysql,还原备份

这篇关于mysql8通过data文件恢复数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1102366

相关文章

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S

使用Python实现网络设备配置备份与恢复

《使用Python实现网络设备配置备份与恢复》网络设备配置备份与恢复在网络安全管理中起着至关重要的作用,本文为大家介绍了如何通过Python实现网络设备配置备份与恢复,需要的可以参考下... 目录一、网络设备配置备份与恢复的概念与重要性二、网络设备配置备份与恢复的分类三、python网络设备配置备份与恢复实

Python实现将MySQL中所有表的数据都导出为CSV文件并压缩

《Python实现将MySQL中所有表的数据都导出为CSV文件并压缩》这篇文章主要为大家详细介绍了如何使用Python将MySQL数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到... python将mysql数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到另一个

SpringBoot整合jasypt实现重要数据加密

《SpringBoot整合jasypt实现重要数据加密》Jasypt是一个专注于简化Java加密操作的开源工具,:本文主要介绍详细介绍了如何使用jasypt实现重要数据加密,感兴趣的小伙伴可... 目录jasypt简介 jasypt的优点SpringBoot使用jasypt创建mapper接口配置文件加密

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解

Oracle存储过程里操作BLOB的字节数据的办法

《Oracle存储过程里操作BLOB的字节数据的办法》该篇文章介绍了如何在Oracle存储过程中操作BLOB的字节数据,作者研究了如何获取BLOB的字节长度、如何使用DBMS_LOB包进行BLOB操作... 目录一、缘由二、办法2.1 基本操作2.2 DBMS_LOB包2.3 字节级操作与RAW数据类型2.