MySQL的备份与恢复

news/2024/12/30 3:41:22/

数据备份的重要性

  1. 备份的主要目的是灾难恢复。

  2. 在生产环境中,数据的安全性至关重要。

  3. 任何数据的丢失都可能产生严重的后果。

  4. 造成数据丢失的原因:

    • 程序错误
    • 人为操作错误
    • 运算错误
    • 磁盘故障
    • 灾难(如火灾、地震)和盗窃

数据库备份的分类和备份策略

数据库备份的分类

1)物理备份

物理备份:对数据库操作系统的物理文件(如数据文件、日志文件等)的备份。

物理备份方法:

  • 冷备份(脱机备份) :是在关闭数据库的时候进行的
  • 热备份(联机备份) :数据库处于运行状态,依赖于数据库的日志文件
  • 温备份:数据库锁定表格(不可写入但可读)的状态下进行备份操作

2)逻辑备份

逻辑备份:对数据库逻辑组件(如:表等数据库对象)的备份。

  • 即以sql语句的形式,把库、表结构、表数据保存下来。

数据库的备份策略

  • 完全备份(全量备份):每次对数据库进行完整的备份。
  • 差异备份:备份自从上次完全备份之后被修改过的文件。
  • 增量备份:只有在上次完全备份或者增量备份后被修改的文件才会被备份

MySQL完全备份介绍

什么是完全备份

  • 完全备份是对整个数据库、数据库结构和文件结构的备份
  • 保存的是备份完成时刻的数据库
  • 是差异备份与增量备份的基础

完全备份的优缺点

优点:备份与恢复操作简单方便

缺点:数据存在大量的重复,占用大量的备份空间,备份与恢复时间长

完全备份的方法

1)物理冷备份与恢复

  • 关闭MySQL数据库
  • 使用tar命令直接打包数据库文件夹
  • 直接替换现有MySQL目录即可

2)mysqldump备份与恢复

  • MySQL自带的备份工具,可方便实现对MySQL的备份
  • 可以将指定的库、表导出为SQL脚本
  • 使用命令mysq|导入备份的数据

完全备份

先关闭数据库,之后打包备份

 systemctl stop mysqld         #先关闭服务mkdir /backup/                #创建备份目录​rpm -q xz                     #使用xz工具进行压缩,检查xz工具是否已安装yum install xz -y             #如果没安装,可以先yum安装tar Jcf /backup/mysql_all_$(date +%F).tar.xz /usr/local/mysql/data  #打包数据库文件。/usr/local/mysql/data 为数据库文件存放目录​cd /backup/        #切换到备份目录 ls                 #查看目录内容tar tf mysql_all_2023-7-1.tar.xz    #查看tar包内的文件 

 完全恢复

将数据库迁移到另一台主机,测试完全恢复。

 #主机A,使用scp命令将tar包传给另一台主机Bscp /backup/mysql_all_2023-7-1.tar.xz 192.168.161.151:/opt​##主机B的操作##systemctl stop mysqld     #关闭mysqlcd /opt/mkdir /opt/bak/            #创建备份目录                  tar Jxf mysql_all_2023-7-1.tar.xz -C /opt/bak/  #将tar包解压到备份目录cd /opt/bak/              #切换到tar包的解压目录cp -af usr/local/mysql/data/ /usr/local/mysql   #将data目录复制到/usr/local/mysql/目录下,覆盖原有文件​systemctl start mysqld       #启动mysqlmysql       #登录数据库查看show databases;use cs;show tables;select * from t1;

逻辑备份(使用mysqldump工具)

mysqldump是常用的逻辑备份工具。

mysqldump可以将指定的库、表导出为SQL脚本。

mysqldump完全备份

1)完全备份一个或多个完整的库(包括库中所有的表)

mysqldump -uroot -p[密码] --databases 库名1 [库名2].. >/备份路径/备份文件名.sql#导出的就是数据库脚本文件​示例:mysqldump -u root -p --databases cs > /opt/mysql_bak/cs.sql    #完全备份一个库jlxmysqldump -u root -p --databases cs market > /opt/mysql_bak/cs-market.sql

2) 完全备份MySQL服务器中所有的库(包括库中所有的表)

 mysqldump -u root -p[密码] --all-databases > / 备份路径/备份文件名.sql​示例:mysqldump -u root -p --all-databases > /opt/mysql_bak/all.sql   #完全备份所有的库

3)完全备份指定库中的部分表

注意:只备份表,sql语句中只有对表的操作,没有对库的操作。恢复时需要人为确认库存在。

 mysqldump -u root -p[密码] [-d] 库名 表名1 [表名2] ... > /备份路径/备份文件名.sql#使用“-d"选项,说明只保存数据库的表结构#不使用“-d”选项,说明表数据也进行备份

 4)查看备份文件
备份文件中保存的是sql语句。即以sql语句的形式,把库、表结构、表数据保存下来。

 cd /opt/mysql_bakcat cs-market.sql | grep -v "^--" |grep -v "^/" |grep -v "^$" 

mysqldump完全恢复

先启动mysql

 systemctl start mysqld

恢复数据库

先删除数据库,之后进行恢复。

##删除数据库yuji##mysql -u root -p -e 'drop database cs;'#"-e"选项,用于指定连接MySQL后执行的命令,命令执行完后自动退出​mysql -u root -p -e 'SHOW DATABASES;'         #查看当前有哪些数据库​##恢复数据库yuji##mysql -u root -p < /opt/mysql_bak/cs.sql     #重定向输入库文件​mysql -u root -p -e 'SHOW DATABASES;'       #查看当前有哪些数据库

2)恢复数据表

当备份文件中只包含表的备份,而不包含创建的库的语句时,执行导入操作时必须指定库名,且目标库必须存在。

 ##备份yuji库中的class表##mysqldump -uroot -p can uu01 > /opt/mysql_bak/can_uu01.sql​##删除yuji库中的class表##mysql -u root -p -e 'drop table can.uu01;'​mysql -u root -p -e 'show tables from can;'     #查看yuji库中的表,已无class表​##恢复yuji库中的class表##mysql -u root -p can < /opt/mysql_bak/can_uu01.sql   #重定向导入备份文件,必须指定库名,且目标库必须存在​mysql -u root -p -e 'show tables from yuji;'


http://www.ppmy.cn/news/779258.html

相关文章

Word查找重复的内容

Word查找重复的内容 第一步.全选WORD中的文字 快捷键 ctrla 第二步.ctrlf 查找内容处 可选择 下面内容 第一种 (^13)([!^13][!^13]){1,} 第三步.点击 “更多” 勾选 使用通配符项 第四步 “阅读突出显示”全部突出显示 介绍 ^13表示段落标记&#xff0c; [!]表示“非”&a…

word 顽固的“信息检索”

最近在写论文&#xff0c;被word的一些小功能折磨疯了。 信息检索这个功能我也不知道是怎么出现的&#xff0c;但是&#xff0c;按住Alt键的同时点右上角的 就可以完全去除。

如何彻底关闭 word 2010 万恶的“信息检索”?

如何彻底关闭 word 2010 万恶的“信息检索”&#xff1f; 在使用 Microsoft office word 2010 编辑文档时&#xff0c;每次想用“Alt 鼠标拖动”作方块选择时&#xff0c;老在右侧打开“信息检测”窗口。这个该死的功能&#xff0c;让我无法做方块选择&#xff0c;恨得我差点…

怎么在一个文件夹内搜索word文章内的关键字?

怎么在一个文件夹内搜索word文章内的关键字&#xff1f; 我想在一个文件夹里搜索到里面word文档的内容&#xff0c;怎么弄呢&#xff1f; https://zhidao.baidu.com/question/557700531.html 勾选文件内容即可

去掉word 2007中可恶的信息检索

word 2007中&#xff0c;有时候会弹出信息检索的窗口&#xff0c;而且很难关掉。在遇到几次后&#xff0c;百度了下解决办法&#xff0c;再次记录下备忘。 按住 alt 键去点信息检索窗口的下拉箭头&#xff0c;可以展示下拉箭头&#xff0c;然后点击 关闭 即可。 (如果不按住 al…

点击word页面自动弹出信息检索很烦人

按住Alt键关闭信息检索&#xff0c;就可以彻底关闭了

在word中查找所有红色字的位置和突出显示的位置

一、需求 查找word文档中所有红色字体的位置。 二、实现 “查找”—>“更多”&#xff08;展开更多&#xff0c;按钮文字切换为更少&#xff09;——>“格式”——>“字体”——>“字体颜色”设置为红色——>确定&#xff0c;如下图&#xff1a; 三、扩展 需…

Word文件打开显示“文件未找到”,处理方法

模板坏了 到C:user\用户名\Application Data\Microsoft\Templates这个文件夹下将Normal.dotm删除后重启word就可以恢复正常了。