MySQL-备份+日志:介质故障与数据库恢复

news2025/1/17 14:08:35

MySQL-备份+日志:介质故障与数据库恢复

  • 第1关:备份与恢复
    • 任务描述
    • 相关知识
    • MySQL的恢复机制
    • MySQL的备份与恢复工具
    • 编程要求
    • 代码参考
  • 第2关 备份+日志:介质故障的发生与数据库的恢复
    • 任务描述
    • 相关知识
    • 编程要求
    • 测试说明
    • 代码参考

第1关:备份与恢复

任务描述

本关任务:
备份数据库,然后再恢复它。

相关知识

为了完成本关任务,你需要掌握:
1.MySQL的恢复机制;
2.MySQL提供的备份与恢复工具。

MySQL的恢复机制

和大多数DBMS一样,MySQL利用备份、日志文件实现恢复。
具体理论知识在此不详细介绍。

MySQL的备份与恢复工具

MySQL提供了以下工具:

  • 逻辑备份工具:mysqldump
  • 物理备份工具:mysqlbackup(仅限商用版)
  • 日志工具:mysqlbinlog
  • 还原工具:mysql
  • 管理工具:mysqladmin

mysqldump
逻辑备份工具,它产生一系的SQL语句,执行这些语句可以重建原数据库的所有对象和数据。缺省输出是控制台,可以通过重定向符号,将其产生的SQL语句集合存入到某个文件。
mysqldump可以备份服务器上的全部数据库,也可以指定某些数据库,或者一个数据库中的某些表。
mysqldump -h127.0.0.1 -uroot -p123123 [options] --databases db_name

–databases 参数用指定数据库名,后面可跟一个或多个数据库的名字,多个数据库名间用空格隔开。
mysqldump命令行工具还可以带若干参数,可选的参数多达几十个,详见官方参考手册。这里只介绍一个:
–flush-logs 刷MySQL日志,即重新开始一个日志文件。
重新开始一个新的日志文件,对未来确定哪些日志更有用很有帮助。通常海量备份前的日志文件,其重要性会降低许多,因为有备份在手,除非备份文件出故障,你可能不再需要使用之前的日志文件。

mysqlbackup
mysqlbackup是MySQL的物理备份工具,只有付费的商用企业版才有。

mysql
mysql是MySQL最重要的客户端管理工具,通常用户都是通过mysql登录到MySQL服务器,进行各种操作。此外,还可以直接通过它执行SQL脚本,还原或创建新库。
mysql -h127.0.0.1 -uroot -p12313 < mydb.sql
这样会直接执行mydb.sql的脚本。通过mysqldump备份出来的脚 本文件,可以用该方法直接用来恢复原数据库。

mysqladmin
mysqladmin是MySQL服务器的管理工具,一般用于配置服务器,也可以用来创建或删除数据库:
mysqladmin [options] command [command-arg] [command [command-arg]]
常用的command(执行命令)有:
create db_name 创建数据库
drop db_name 删除数据库
flush-logs 刷日志
flush-tables 刷表,所有表数据写入磁盘盘
kill id,id,… 杀死某些进程
password new_password 修改(登录者的)登录密码
ping 检查服务器是否可用
status 显示服务器状态
variables 显示各配置参数的值

同样,该工具也支持不少可选的参数,详见官方手册。

mysqlbinlog
mysqlbinlog是MySQL的日志管理工具。在需要手工介入的故障恢复中,该工具必不可少。当然,平常也可以用它查看日志。
mysqlbinlog mysql-bin.000983
上面的例子,用来查看日志文件mysql-bin.000983。MySQL的日志文件具有相同的前缀,后面的数字是日志文件的顺序。这个前缀是可配置的。比如,也可能是binlog.*,例如:
日志文件

执行日志文件会导致日志所记录的事件重新做一遍,这样可以恢复一个给定时间段的数据,恢复的方法如下:
mysqlbinlog [option] binlog_files | mysql -u root -p
介质故障的恢复通常需要把最近一次备份后所有的日志文件全部列上。

mysqlbinlog也支持几十个可选的参数,比如:
–disable-log-bin 在通过日志恢复数据库期间不再写日志
–no-defaults 不使用MySQL默认的设置

其它参数数详情请参考官方文档。

MySQL还有其它一些工具(如mysqlimport,mysqlshow等),这里不一一介绍。

编程要求

设有居民人口登记数据库residents,请为该数据库做一次静态的(你一个人独享服务器)海量逻辑备份,备份文件命名为residents_bak.sql。 然后再用该逻辑备份文件恢复数据库。
评测程序并不检查备份文件的名字,你可以用其它文件名,但要保证备份和恢复时,使用同一个文件。备份和恢复的命令分别写在test1_1.sh和test1_2.sh文件中。

  • test1_1.sh - 作备份
  • test1_2.sh - 作恢复

切莫把两个文件弄反了。

根据提示,在右侧代码文件编辑器填写语句,完成上述要求。缺 省情况下你看到的应该是test1_1.sh。鼠标移至“代码文件”右侧的三角符号,会列出全部代码文件,你可以在两个代码文件间自由切换。当所有代码文件都填写完成后,点击“评测”按钮。

注意:mysql,mysqldump,mysqladmin运行时需提供登录用户名和密码,由于不是在交互式环境中使用这些工具,你需要在命令行上给出登录所需要的信息,例如:
mysql -h127.0.0.1 -uroot -p123123
但在命令行曝光密码具有极高风险,MySQL会抛出警告信息,故评测程序会通过其它途径提供登录密码,请在命令行省略-p参数。以mysql为例,你只需要这样写即可:
mysql -h127.0.0.1 -uroot

测试说明
数据库residents是本来就有的,平台会先运行test1_1.sh来作备份,然后会drop掉residents。再运行test1_2.sh来恢复数据库。最后检查恢复是否成功,如果在每个residents实列上的评测结果,都与预期结果完全一致即过可通关。

开始你的任务吧,祝你成功!

代码参考

test1_1.sh 文件内容

# 你写的命令将在linux的命令行运行
# 对数据库residents作海量备份,备份至文件residents_bak.sql:
mysqldump -h127.0.0.1 -uroot --flush-logs --databases residents > residents_bak.sql

test1_2.sh 文件内容

# 你写的命令将在linux的命令行运行
# 利用备份文件residents_bak.sql还原数据库:
mysql -h127.0.0.1 -uroot < residents_bak.sql

第2关 备份+日志:介质故障的发生与数据库的恢复

任务描述

本关任务:

模拟介质故障的发生,以及如何利用备份和备份之后的日志恢复数据库。

相关知识

只要有备份文件,和自上次备份以来的日志文件,即使发生介质故障导致整个数据库丢失,也可以在更换介质后,恢复数据库。上一关已介绍有关知识。

在生产环境中,数据库文件、备份文件、日志文件都不会存放在同一介质上,甚至都不会存放在同一地理空间。为的就是灾难发生后,有机会恢复数据。

本关将摸拟介质故障的发生与数据库的恢复。你要使用的工具包括:

  • mysql
  • mysqldump
  • mysqlbinlog

上一关已经介绍了它们的用法。

编程要求

摸拟介质故障的发生与数据库的恢复。依时间顺序发生下列事件(其中标记为红色的部分将由你来完成,其余部分由评测程序完成):

时间点1:数据库train有业务数据产生;
时间点2:对数据库train作一次海量备份,同时新开日志;
时间点3:数据库train又有业务数据产生;
时间点4:故障发生;
时间点5:恢复数据库,保证两次发生的业务数据都不丢失。

请你完成时间点2和时间点5(标注红色的部分)的工作,将完成任务的脚本填写到对应文件中:

  • 对数据库train作一次海量逻辑备份同时开新日志:test2_1.sh
  • 利用备份文件和日志文件恢复数据库: test2_2.sh

切莫把两个文件弄反了。

所有其它工作,评测程序会替你完成:

  • 在发生业务数据的时间点,会批量写入数据;
  • 在故障发生的时间点,数据库train会被drop掉。
  • 在drop数据库之前,评测程序会将备份后新开的日志文件保存为log/binlog.000018

这里,评测程序总是替你找到你需要的那个日志文件,并保存在一个固定的日志文件中,供你恢复使用。但在实践中,日志文件是一直在变化的,即便是在这样一个由你独享服务器实例的环境下,两次点击“评测”按钮,日志文件也会因评测程序多次写入数据,加上你的备份与恢复操作而发生变化,当日志文件达到一定规模时,MySQL还会自动开启新日志文件。在本地实验时,自己要学会识别你需要哪个或哪些日志文件。

请根据提示,在右侧代码文件编辑器填写语句,完成上述要求。缺 省情况下你看到的应该是test2_1.sh。鼠标移至“代码文件”右侧的三角符号,会列出全部代码文件,你可以在两个代码文件间自由切换。当所有代码文件都填写完成后,点击“评测”按钮。

测试说明

评测程序将按照时间顺序触发上述相应事件,在轮到时间点2和时间点5时,运行你的脚本。在所有事件结束后检查数据库有没有成功恢复。如果在数据库的两个不同实例上,故障发生后,数据库都得以完全恢复,即可通关。

开始你的任务吧,祝你成功!

代码参考

test2_1.sh 文件内容

# 这是shell脚本,将在linux命令行上执行
# 命令行上可省略密码的指定
# 请写出对数据库train作逻辑备份并新开日志文件的命令,备份文件你可以自己命名(如train_bak.sql):
mysqldump -h 127.0.0.1 -uroot --flush-logs --databases train > backup/train_bak.sql

test2_2.sh 文件内容

# 这是shell脚本,将在linux命令行上执行
# 命令行上可省略密码的指定
# 请写出利用逻辑备份和日志恢复数据库的命令:
mysql -h127.0.0.1 -uroot < backup/train_bak.sql
mysqlbinlog --no-defaults log/binlog.000018 | mysql -h127.0.0.1 -uroot

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/540381.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《分布式微服务电商源码》-项目简介

1.常见的电商模式 市面上有 5 种常见的电商模式 B2B、B2C、C2B、C2C、O2O 1.1.B2B 模式 B2B(Business to Business)&#xff0c;是指商家和商家建立的商业关系&#xff0c;如阿里巴巴. 1.2.B2C 模式 B2C(Business to Consumer) 就是我们经常看到的供应商直接把商品买个用户&a…

057:cesium设置纯颜色材质

第057个 点击查看专栏目录 本示例的目的是介绍如何在vue+cesium中设置纯颜色的材质,颜色的表达方式可以参考这篇文章 Cesium七种方法设置颜色 直接复制下面的 vue+cesium源代码,操作2分钟即可运行实现效果. 文章目录 示例效果配置方式示例源代码(共87行)相关API参考:专…

用友BIP新零售产品发布,与零售企业共创新未来

随着数智化时代的到来&#xff0c;零售企业不断面临着更多的挑战和机遇。为了满足消费者多元化的需求&#xff0c;零售企业需要采用多种方式来提高竞争力&#xff0c;如多渠道销售、线上线下融合、数智化运营、个性化营销和无缝化体验等。用友BIP新零售为零售企业提供了数智化转…

Jenkins的持续集成与持续部署

系统总体架构 Gitlab Gitlab是一款主要用于代码管理的工具&#xff0c;相较于GitHub&#xff0c;可以自己搭建服务器&#xff0c;这可以避免因为网络速度慢导致部署效率低下&#xff0c;同时&#xff0c;自己搭建服务器&#xff0c;安全性更高。Jenkins Jenkins主要用于管理版本…

改图片分辨率:提升图像质量的关键步骤

无论您是一名摄影师、设计师&#xff0c;还是一个爱好者&#xff0c;改变图片分辨率都是必不可少的工作。在本文中&#xff0c;我们将介绍改图片分辨率的作用以及它在哪些场景下使用。 改图片分辨率介绍 图片分辨率是指图像中所包含的像素数量&#xff0c;通常以“每英寸像素…

threejs 相机OrbitControls常用方法及属性

相机控件OrbitControls 通过OrbitControls可以对三维场景进行缩放、平移、旋转&#xff0c;本质上改变的不是场景&#xff0c;而是相机的参数&#xff0c;相机的位置角度不同&#xff0c;同一个场景的渲染效果是不一样&#xff0c;比如相机围绕着一个场景旋转&#xff0c;就像…

有哪些工具软件一旦用了就离不开?

&#x1f496;前言 目前&#xff0c;随着科技的快速发展&#xff0c;电脑已经进入了许许多多人的生活 &#xff0c;在平日的学习、工作和生活里&#xff0c;我们会用的各种各样的强大软件。市面上除了某些大公司开发在强大软件&#xff0c;还有各路大神开发具有某些功能的强大…

nodejs+vue网上课程在线教学网站平台a53y0

(1) vue引入elementui 1.使用npm安装element-ui npm i element-ui -S 2.在main.js中导入使用vue import element-ui/lib/theme-chalk/index.css //别忘了导入样式 import ElementUI from element-ui Vue.use(ElementUI) 后端&#xff1a;java(springbootssm)/python/php/node…

MySQL入门到精通——运维篇(基础篇——进阶篇——运维篇)本文以MySQL8.0版本以上为例

文章目录 前言MySQL——运维篇一、日志1.日志-错误日志2.日志-二进制日志3.日志-查询日志4.日志-慢查询日志 二、主从复制1.主从复制-概述2.主从复制-原理3.主从复制-搭建3.1.主从复制-搭建-主库配置3.2.主从复制-搭建-从库配置3.2.主从复制-搭建-测试 三、分库分表1.分库分表-…

Nacos简介和安装

1.Nacos简介 1.1.为什么叫Nacos 前四个字母分别为Naming和Configuration的前两个字母&#xff0c;最后的s为Service。 1.2.是什么 一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。Nacos: Dynamic Naming and Configuration ServiceNacos就是注册中心&am…

Fiddler 到底能做什么?一篇文章给你详细介绍

Fiddler是检查 Http 流量的最流行的工具之一。此工具可帮助我们非常轻松地测试 REST API / SOAP Web 请求。 题主的问题&#xff1a;Fiddler 到底能做什么。仔细思考&#xff0c;其实有两层意思&#xff1a; 第一层&#xff1a;Fiddler工具的应用范围 第二层&#xff1a;Fiddl…

手搓哈希表

手搓哈希 哈希概念哈希冲突为什么会有哈希冲突的产生?常见的哈希函数 如何解决哈希冲突&#xff1f;闭散列闭散列的简单模拟实现插入查找删除 总代码开散列开散列的模拟实现插入删除查找 存在的问题迭代器 开散列总的代码 哈希概念 顺序结构以及平衡树中&#xff0c;元素关键码…

在研制带处理器的电子产品时,如何提高抗干扰能力和电磁兼容性?

一、下面的一些系统要特别注意抗电磁干扰 1、微控制器时钟频率特别高&#xff0c;总线周期特别快的系统。 2、系统含有大功率&#xff0c;大电流驱动电路&#xff0c;如产生火花的继电器&#xff0c;大电流开关等。 3、含微弱模拟信号电路以及高精度A/D变换电路的系统。 二、…

GPU物理位置查询:从nvidia编号到物理位置

supermicro AS -4125GS-TNRT 服务器GPU出现问题&#xff0c;有几张GPU速度较慢。需要确定其物理位置,具体流程如下&#xff1a; 1 GPU编号与BUS_ID对应关系 使用nvidia-smi即可查看&#xff0c;如下所示&#xff1a;![在这里插入图片描述](https://img-blog.csdnimg.cn/3807d…

分布式锁解决方案_基于Redisson实现的分布式锁实现

Redisson介绍&#xff1a; https://github.com/redisson/redisson/wiki Redisson - 是一个高级的分布式协调Redis客服端&#xff0c;能帮助用户在分布式环境中轻松实现一些Java的对象&#xff0c;Redisson、Jedis、Lettuce是三个不同的操作 Redis 的客户端&#xff0c;Jedis、…

常见的8种用户需求评估方法

1、人性法 在评估用户需求时&#xff0c;需要判断这个需求所实现的功能&#xff0c;是否符合人性&#xff0c;与哪几种人性相匹配&#xff0c;如果非常匹配则值得做。当然并不是需求反应的人性越多越好&#xff0c;需要根据团队实际资源做到极致。 如格林人性法则包括&#xff…

【已解决】Arduino编译错误error: ordered comparison of pointer with integer zero的解决方法

在使用Arduino的资源库对STM32编程时&#xff0c;出现&#xff1a; error: ordered comparison of pointer with integer zero (byte* {aka unsigned char*} and int) 编译错误的解决方法。 Arduino因其开源和易用性&#xff0c;丰富的三方资源&#xff0c;受到很多人的喜欢…

CCIG 2023 从视觉-语言模型到智能文档图像处理

前言 一、视觉-语言模型是什么&#xff1f; 二、视觉-语言模型可以用来做什么&#xff1f; 三、视觉-语言 预训练模型 3.1、模型架构 3.2、训练目标 3.2.1、图像-文本匹配损失&#xff08;ITM&#xff09; 3.2.2、掩码语言建模损失&#xff08;MLM&#xff09; 3.2.3、…

Shell基础学习---4、文本处理工具、综合应用案例(归档文件、发送信息)

1、文本处理工具 1.1 cut cut的工作就是“剪”&#xff0c;具体的说就是在文件中负责剪切数据用的。cut命令从文件的每一行剪切字节、字符和字段并将这些字节、字符和字段输出。 1、基本语法 cut [选项参数] filename 说明&#xff1a;默认分割符是制表符 2、选项参数说明 选…

AOP设计思想与实用

文章目录 一、AOP思想&#xff08;一&#xff09;什么是AOP&#xff08;二&#xff09;为什么要使用AOP 二、Spring AOP&#xff08;一&#xff09;AOP 的组成1. Join Point&#xff08;连接点&#xff09;2. Pointcut&#xff08;切点&#xff09;3. Advice&#xff08;通知&a…