导读 跟大家讲解下有关MySQL 介绍完全备份与恢复,相信小伙伴们对这个话题应该也很关注吧,现在就为小伙伴们说说MySQL 介绍完全备份与恢复
跟大家讲解下有关MySQL 介绍完全备份与恢复,相信小伙伴们对这个话题应该也很关注吧,现在就为小伙伴们说说MySQL 介绍完全备份与恢复,小编也收集到了有关MySQL 介绍完全备份与恢复的相关资哈尔滨工业大学地址料,希望大家看到了会喜欢。
免费学习推荐:mysql视频教程
文章目录
前言一、MySQL 完全备份1.数据库备份方式精讲1.1 数据库备份的重要性1.2 数据库备份的分类1.2.1 物理备份1.2.2 逻辑备份1.2.3 完全备份1.2.4 差异备份1.2.5 增量备份1.2.6 备份方式比较1.3 MySQL 完全备份概念解读2.mysqldump 备份演练2.1 使用 tar 打包文件夹备份2.2 使用 mysqldump 工具备份二、MySQL 完全恢复1.恢复整库操作1.1 source 命令整库恢复1.2 MySQL 命令整库恢复2.恢复表操作2.1 使用 source 命令恢复表2.2 使用 mysql 命令恢复表3.MySQL 备份思路
前言
随着办公自动化和电子商务的飞速发展企业对信息系统的依赖性越来越高数据库作为信息系统的核心担当者重要的角色数据库备份是在数据丢失的情况下能及时恢复重要数据防止数据丢失的一种重要手段一个合理的数据库备份方案能够在数据丢失时有有效地恢复数据而且也需要考虑技术实现难度和有效地利用资源
一、MySQL 完全备份
1.数据库备份方式精讲
1.1 数据库备份的重要性
生产环境中数据的安全性是至关重要的任何数据的丢失都可能产生严重的后果
数据库备份的重要性主要体现在:
提高系统的高可用性和灾难可恢复性在数据库系统崩溃时没有数据库备份就没法找到数据使用数据库备份还原数据库是数据库崩溃时提供数据恢复最小代价的最优方案如果让用户重新添加数据代价未免太大没有数据就没有一切数据库备份是一种防范灾难的强力手段
使用数据库的过程中有多种原因造成数据的丢失:
程序错误:指对数据库操作的程序难免有些错误造成数据丢失人为错误:指由于使用人员的误操作造成的数据被破坏还有可能是黑客对系统攻击造成的数据丢失等计算机失败:指运行数据库的服务器操作系统或软件损坏有可能造成数据的损坏磁盘失败:指硬盘等存储数据的硬件设备长时间运行后可能损坏造成数 据丢失灾难(如火灾、地震)和偷窃:指自然灾害等的发生有可能造成数据丢失
数据丢失会造成严重的经济损失如携程网2015年5月28日数据库崩溃每小时损失大概106万美元所以在企业信息系统建设中数据库的备份管理是非常重要的内容1.2 数据库备份的分类
备份方式分很多种从物理与逻辑的角度备份可分为以下几类:
1.2.1 物理备份指对数据库操作系统的物理文件(如数据文件、日志文件等)的备份物理备份又可以分为脱机备份(冷备份)和联机备份(热备份)冷备份(脱机备份):在关闭数据库时进行的备份操作能够较好地保证数据库的完整性热备份(联机备份):在数据库运行状态中进行操作这种备份方法依赖于数据库的日志文件1.2.2 逻辑备份指对数据库逻辑组件(如表等数据库对象)的备份
从数据库的备份策略角度来看备份又可分为完全备份、差异备份和增量备份
1.2.3 完全备份每次对数据进行完整的备份可以备份整个数据库包含用户表、系统表、索引、视图和存储过程等所有数据库对象但它需要花费更多的时间和空间所以做一次完全备份的周期要长些1.2.4 差异备份备份那些自从上次完全备份之后被修改过的文件即只备份数据库部分的内容它比最初的完全备份小因为只包含自上次完全备份以来所改变的数据库它的优点是存储和恢复速度快1.2.5 增量备份只有那些在上次完全备份或者增量备份后被修改的文件才会被备份1.2.6 备份方式比较备份方式完全备份差异备份增量备份完全备份时的状态表1、表2表1、表2表1、表2第1次添加内容创建表3创建表3创建表3备份内容表1、表2、表3表3表3第2次添加内容创建表4创建表4创建表4备份内容表1、表2、表3、表4表3、表4表4完全备份每次都是把整个数据库中的内容进行备份差异备份在第1次添加内容后备份即备份新添加的内容;第2次添加内容后备份把第1次添加的内容也进行了备份它是根据完全备份时的状态决定的差异备份每次都是把完全备份之后所有的修改进行备份而不管之前是否做过差异备份增量备份只备份每次新修改的内容第1次创建表3就对表3备份第2次添加表4后因为之前已经备份过表3所以只备份表4的内容
1.3 MySQL 完全备份概念解读
MySQL 的备份方式主要有完全备份与增量备份完全备份是对整个数据库的备份、数据库结构和文件结构的备份保存的是备份完成时刻的数据库是增量备份的基础完全备份的优点是备份与恢复操作简单方便缺点是数据存在大量重复占用大量的备份空间备份的时间长在生产环境中这两种备份方式都会使用需要制定合理高效的方案达到备份数据的目的避免数据丢失造成严重的后果
2.mysqldump 备份演练
MySQL 数据库的备份可以采用两种方式因为数据库实际上就是文件直接打包数据库文件夹或者是使用专用备份工具 mysqldump 都可以进行备份工作
2.1 使用 tar 打包文件夹备份
MySQL 的数据库文件默认都是保存在安全目录的 data 文件夹下可以直接保存 data 文件夹因为占用空间较大可以使用data 打包压缩进行保存
yum -y install xz#数据库文件很大可以使用压缩率较大的xz格式压缩首选需要安装xz压缩格式工具tar Jcvf /opt/mysql-$(date +%F).tar.xz /usr/local/mysql/data/#对数据库文件夹进行打包操作ls /opt#查看打包命令是否运行成功已经生成了备份文件du -sh /opt/mysql-2021-02-05.tar.xz #对比打包前后的文件大小可以看到压缩的备份文件所占用空间很小tar -Jxvf /opt/mysql-2021-02-05.tar.xz -C /usr/local/mysql/data/systemctl restart mysql#如果数据库文件损坏数据丢失可以解压缩文件相当于数据恢复
2.2 使用 mysqldump学信网学历入口官网 工具备份
上文中演示的是对 MySQL 整个数据库的目录进行压缩的方式是备份数据库中所有的内容mysqldump 是 mysql 用于转存储数据库的实用程序(自带)它主要产生一个 SQL 脚本其中包含从头重新创建数据库所必需的命令(如 CREATE、TABLE、INSERT等)使用 mysqldump 可以更加灵活地控制备份的内容比如某几个表或库都可以单独备份
#开始之前创建库和表用作例子mysql -uroot -p123123#输入密码进入数据库以上为我的密码create databa SCHOOL;#创建库u SCHOOL;create table CLASS01 ( id int(2) not null auto_increment, name varchar(10) not null, x char(5) not null, hobby varchar(10), primary key (id));#创建表结构#字段一:id最大显示长度2不能为空自动递增从1开始#字段二:name可变长度字段10不能为空#字段三:x固定长度5不能为空#字段四:hobby可变长度最多10字符#字段四:主键(id)inrt into CLASS01 values(1,'wangyi','man','reading');inrt into CLASS01 values(2,'wanger','woman','singing');#插入2条数据lect * from CLASS01;#检查一下quit#退出数据库
#使用 mysqldump 对某些表进行完全备份命令格式如下:mysqldump -u[用户名] -p[密码] [选项] [数据库名] [数据表名] > /备份路径/备份文件名.sql#导出的为数据库脚本文件例:对库SCHOOL中的表class进行备份至/opt/目录下mysqldump -uroot -p[密码] SCHOOL CLASS01 > /opt/test01.sql
#对某些库进行完全备份mysqldump -uroot -p[密码] [数据库名] > /目录/备份文件名.sql例:mysqldump -uroot -p123123 SCHOOL > /opt/test02#对多个库进行完全备份mysqldump -uroot -p123123 --databas SCHOOL sys > /opt/test03.sql#对所有库进行完全备份mysqldump -uroot -p123123 --all-databas > /opt/test04.sql#直接备份表结构mysqldump -uroot -p123123 -d SCHOOL CLASS01 > /opt/test05.sqlls /opt/#查看打包命令是否运行成功已经生成了备份文件
cat /opt/test05.sql#分析 mysqldump 工具生成的备份文件的内容
上面使用了 -d 选项说明只保存数据库的表结构且表中只有一个库可以看到先删除了表(同名)再创建了它删除和创建都是最普通的 MySQL 命令任何一条在 MySQL 中都是可以执行的语句有了这些语句就可以创建出和现在的表结构相同的表如果不使用 -d 选项会把数据也进行备份下面看看数据时如何保存的
cat 湖北中考时间/opt/test01
可以看到与使用 -d 参数的差别是最后出现了 inrt into 语句往数据库中插入了两条数据也就是说数据的备份是保存的插入语句操作通过以上分析很容易理解备份的本质就是保存数据库当美国夏令营前表结构的创建语句和现有数据的插入语句有了它们就可以直接恢复数据库的状态
二、MySQL 完全恢复
前面介绍了数据库的完全备份使用 mysqldump 工具可以把数据的创建语句保存在备份的脚本文件中当出现错误时可以使用以下几种方法恢复它们
1.恢复整库操作
1.1 source 命学习教育法心得体会令整库恢复
mysql -uroot -p123123show databas;drop databa SCHOOL;show databas;source /opt/test03.sql#之前备份过的该备份为SCHOOL和sys两个库的完整备份#注意!选项得加“--databas”才是完整的备份不然会恢复不了
1.2 MySQL 命令整库恢复
quitmysql -uroot -p123123 -e 'drop databa SCHOOL;'mysql -uroot -p123123 -e 'SHOW DATABASES;'mysql -uroot -p123123 < /opt/test03.sql mysql -uroot -p123123 -e 'SHOW DATABASES;'
2.恢复表操作
恢复数据表同样可以使用 source 命令和 mysql 命令操作
2.1 使用 source 命令恢复表
mysql -uroot -p123123u SCHOOL;show tables;drop table CLASS01; source /opt/test01.sql#恢复表show tables;lect * from CLASS01;#查看
2.2 使用 mysql 命令恢复表
quitmysql -uroot -p123123 -e 'SHOW TABLES FROM SCHOOL;'mysql -uroot -p123123 -e 'DROP TABLES SCHOOL.CLASS01;'mysql -uroot -p123123 -e 'SHOW TABLES FROM SCHOOL;'mysql -uroot -p123123 SCHOOL < /opt/test01.sqlmysql -uroot -p123123 -e 'SHOW TABLES FROM SCHOOL;'
3.MySQL 备份思路
MySQL 需要定期实施备份指定合适的备份计划或策略并严格遵守除了进行完全备份开启 MySQL 服务器的日志功能也很重要完全备份加上日志可以对 MySQL 进行最大化还原备份文件的名字还需钥使用统一的易于理解的名称推荐使用库名或表名加上时间的命名规则在需要恢复数据库时能很容易的定位到相应的所需备份文件
相关免费学习推荐:mysql数据库(视频)
以上就是MySQL 介绍完全备份与恢复的详细内容!
来源:php中文网
本文发布于:2023-02-24 17:35:01,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/167723130130186.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:互联网常识:MySQL 介绍完全备份与恢复.doc
本文 PDF 下载地址:互联网常识:MySQL 介绍完全备份与恢复.pdf
留言与评论(共有 0 条评论) |