问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

MySQL备份的几种常用

发布网友 发布时间:2022-04-21 15:26

我来回答

2个回答

热心网友 时间:2022-04-07 18:11

数据备份是数据容灾的最后一道防线,即便有着两地三中心的架构,备份也依然重要。如果备份出问题,备份时影响了交易业务,备份数据无法恢复,这些也是企业难以承受的。所以选择合适的备份工具尤为重要。


每个企业级数据库都会有配套的备份工具,MEB(MySQL Enterprise Backup)就是MySQL企业版中非常重要的工具之一,是为企业级客户提供的数据备份方案。


Xtrabackup一直作为MEB 开源版备胎而存在,从MySQL 8.0开始情况可能会变得有所不同。


在 MySQL 8.0的Backup Lock、Redo Log Archiving、Page Tracking等新特性的加持下,MEB备份/恢复体验会更好,目前xtrabackup还不支持这些特性。


MySQL 企业版还有哪些功能?


特性1:Backup Lock


8.0之前使用xtrabackup或MEB做物理备份,为了保证备份时InnoDB引擎表与其他引擎数据文件、及binlog日志的一致性会上全局读锁,再拷贝非InnoDB文件,这期间MySQL会变成只读,数据无法写入。表数量越多,可能加上时间越长,如果使用的xtrabackup 不小心没加rsync参数,逐个拷贝frm文件,锁定时间会更长,对业务影响较大。


我曾遇到过部署在虚拟机的实例有12000多张表,当时使用的xtrabackup,备份脚本中没加rsync参数,结果锁了十几分钟,而MEB就没有这样的问题。


MySQL 8.0支持轻量级备份锁 LOCK INSTANCE FOR BACKUP,数据字典也重构了由InnoDB存储。若不创建非InnoDB表,MEB默认使用备份锁获取binlog日志一致性位置,并阻止DDL操作,但不影响DML操作。


热心网友 时间:2022-04-07 19:29

1.mysqlmp
在日常工作中,我们会使用mysqlmp命令创建sql格式的转储文件来备份数据库。或者我们把数据导出后做数据迁移,主备搭建等操作。mysqlmp是一个逻辑备份工具,复制原始的数据库对象定义和表数据产生一组可执行的SQL语句。 默认情况下,生成insert语句,也能生成其它分隔符的输出或XML格式的文件。
shell> mysqlmp [arguments] > file_name
我们简单的来看一下日常的用法:
备份所有的数据库:
shell> mysqlmp --all-databases > mp.sql (不包含INFORMATION_SCHEMA,performance_schema,sys,如果想要导出的话还要结合--skip-lock-tables和--database一起用)
备份指定的数据库:
shell> mysqlmp --databases db1 db2 db3 > mp.sql
当我们只备份一个数据的时候可以省去 --databases 直接写成:mysqlmp test > mp.sql 不过有一些细微的差别,如果不加的话,数据库转储输出不包含创建数据库和use语句,所以可以不加这个参数直接导入到其它名字的数据库里
当然我们也可以只备份某个表 :
mysqlmp --user [username] --password=[password] [database name] [table name] table_name.sql
了解了简单的一些用法后我们再着重的看一下几个参数:
--master-data 获取备份数据的Binlog位置和Binlog文件名,用于通过备份恢复的实例之间建立复制关系时使用,该参数会默认开启。
--mp-slave 用于在slave上mp数据,建立新的slave。因为我们在使用mysqlmp时会锁表,所以大多数情况下,我们的导出操作一般会在只读备库上做,为了获取主库的Relay_Master_Log_File和Exec_Master_Log_Pos,需要用到这个参数,不过这个参数只有在5.7以后的才会有
–no-data, -d 不导出任何数据,只导出数据库表结构
刚刚我们说过在使用mysqlmp的时候会锁表,我们来详细的看一下它的锁机制。
我们开两个窗口,在第一个里面执行mysqlmp -uroot -pxxxxx --master-data=2 --databases dbname > /tmp/dbnamedate +%F.sql
然后第二个窗口登陆进去,使用show process的命令可以看到目前mp的session正在执行
1.png
SELECT /*!40001 SQL_NO_CACHE */ * FROM table_name; 可以看到这条sql正在以no_cache的模式查询数据。
然后我们在同样的表上执行一下select,发现被阻塞了。光标一直不返回。
2.png
一般遇到这种文件,我们会想是不是有锁呢?
为了验证我们查看一下锁的信息,可以发现mp的进程实际上是加了锁的。
3.png
我们把具体的general_log打开,然后看一下当时的操作:
4.png
4101044 Query FLUSH /*!40101 LOCAL */ TABLES
4101044 Query FLUSH TABLES WITH READ LOCK (关闭所有打开的表,同时对于所有数据库中的表都加一个读锁,直到显示地执行unlock tables,该操作常常用于数据备份的时候。)
4101044 Query SHOW MASTER STATUS(这是因为我用了--master-data=2)
所以这个时候表就会被锁住。
如果我不加--master-data参数(mysqlmp -uroot -pxx --databases db > /tmp/dbnamedate +%F.sql) mysql会显示的对每一张要备份的表执行
LOCK TABLES table_name1 READ,LOCK TABLES table_name2 READ
并且也不会有读的阻塞。
那有没有不锁的方法,其实也是有的,就是使用--single-transaction把备份的操作放在一个事务里去进行
带上--single-transaction参数的mysqlmp备份过程:
如果是5.6版本的mysql
三种mysql备份方式让你轻松备份数据mysql三种备份方式

定时备份是一种最常见的备份方式,它可以根据用户设定的时间计划进行备份,如每天、每周、每月等。通过定时备份,可以保证数据在最短时间内得到恢复,并且不会因为疏忽忘记备份而导致数据损失。使用定时备份需要以下步骤:Step 1:创建备份脚本 备份脚本可以是一个shell脚本或bat脚本,内容包括连接MySQL数据库、...

mysql数据库备份和还原的常用命令小结

一、备份常用命令 1. 使用`mysqldump`工具进行逻辑备份:`mysqldump -u 用户名 -p 数据库名 > 备份文件.sql`解释:`mysqldump`是MySQL提供的逻辑备份工具,可以通过导出数据库或表的结构及数据到SQL文件的方式备份。命令中的`-u`参数用于指定用户名,`-p`参数用于提示输入密码,`数据库名`是需要备份...

深入了解MySQL三种备份策略数据安全备份不可少mysql三种备份

1. 定期备份MySQL数据。数据备份的最佳实践是每天备份MySQL数据。如果您拥有高流量和敏感的数据,可能会考虑使用每小时或每分钟备份。2. 储存备份数据的位置应该安全。数据备份必须存储在安全的地方,如加密的云存储或备份设备上,这样未经授权的访问才能避免。最好将自动备份存储在远程地点,以防服务器上发...

MySQL数据库备份和还原的常用命令小结

备份MySQL数据库,主要有以下几种方式:全面备份整个数据库:使用`mysqldump -hhostname -uusername -ppassword databasename > backupfile.sql`删除表备份:添加`--add-drop-table`参数,如`mysqldump --add-drop-table -uusername -ppassword databasename > backupfile.sql`压缩备份:`mysqldump -hh...

浅谈MySQL数据库备份的几种方法

mysql常见的备份方式有:mysqldump、mysqlhotcopy、BACKUP TABLE 、SELECT INTOOUTFILE,又或者备份二进制日志(binlog),还可以是直接拷贝数据文件和相关的配置文件。MyISAM表是保存成文件的形式,因此相对比较容易备份,上面提到的几种方法都可以使用。Innodb 所有的表都保存在同一个数据文件 ibdata1中(也可能是多个文件,...

MySQL几种方法的数据库备份

MySQL数据库算是经常使用的数据库中最好使用的数据库了,对于备份的操作也不例外。所以今天分享一下MySQL数据库的备份的几种方式。方式一:使用命令行的方式。命令行的方式较为快捷。仅仅须要在命令行中使用mysqldump命令就可以,默认情况下该命令在mysql的bin文件夹中(前提须要将bin文件夹加入到path中),...

MySQL中备份的几种方式

mysqldump常用的备份参数-R --events --triggers=true --single-transaction --master-data=2-R(--routines): 导出存储过程以及自定义函数--events: 导出事件--triggers=true:导出触发器.默认开启,用--skip-triggers禁用--single-transaction:该选项在导出数据之前提交一个BEGIN SQL 语句,...

如何备份mysql queries

一、MySQL备份类型 1.热备份、温备份、冷备份 (根据服务器状态)热备份:读、写不受影响;温备份:仅可以执行读操作;冷备份:离线备份;读、写操作均中止;2.物理备份与逻辑备份 (从对象来分)物理备份:复制数据文件;逻辑备份:将数据导出至文本文件中;3.完全备份、增量备份、差异备份 (从数据...

MySQL三重备份保障你的数据安全mysql三备份

MySQL三重备份指的是对MySQL数据库进行三份备份,分别存储在主机本地、备份服务器、云存储服务器中,以保证在任何一种情况下都不会出现数据丢失的问题。其原理如下所述:1.本地备份 本地备份指的是将备份数据存储在主机本地磁盘上。这种备份方式速度较快,同时也方便进行数据恢复。因此,在我们进行数据...

MySQL备份的几种常用

mysqlbackup --incremental-backup-dir=backup_incr --trace=3 --incremental=page-track --incremental-base=history:last_full_backup backupincremental-base有3种选择 last_backup:基于前一次备份做增备,前一次备份可能是增备,也可能是全备。这种方式全备之间可能会有多个增备,每次增量可能比较小,...

常用的备份类型 常用的数据库备份方法 手机上存的数据有几种备份方式 常见的备份方式有哪些 数据备份常用方式 备份的类型有哪三种 手机有哪几种备份方式 iphone备份有几种方法 手机备份软件有哪几种
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
微软Win10 DirectX 12 Ultimate正式发布:如何统一AMD/NVIDIA PC显卡和X... 台湾咖啡店品牌有哪些 RedmiBook13首卖4199元,哪些配置的双十二尝鲜价分别是多少? 陂西镇自然环境 鹰凰斗破苍穹简介 骜鹰斗破苍穹简介 三原县陂西镇派出所所长电话 三原县陂西镇初级中学简介 同时用两种洗面奶好吗? 小屁孩日记:屁事多基本信息 独立显卡GT、GTX、HD这些开头的显卡有什么区别? mysql大网站数据库的备份,怎么进行增量备份和完全备份快速一点,用什么工具吗,还是代码! 性价比高的独立显卡 mysql 增量备份完 数据库里为什么多了 独立显卡和非独立显卡有什么区别 如何将电脑的显卡(我家是独立显卡) 怎么超频? Mysql数据库备份工具有哪些? 有什么超极本是带着独立显卡 mysql自动完全备份和增量备份? 独立显卡怎样超频?不用软件. mysql中用哪条命令进行增量备份??? 独立显卡和集成显卡的区别是什么,各自的特点是什么? mysql用mysqldump进行增量备份,如何搞啊?有详细... mysql 大数据量备份方式 哪些笔记本有独立显卡? MYSQL备份:启用二进制日志功能的MYSQL增量备份 超级独立显卡:NVIDIA GeForce 8400M win7系统下mysql如何增量备份 有配独立显卡的超极本么? 有什么简单的 mysql 增量备份方案 mysql增量备份的疑问 谁能说说英特尔的独立显卡??? 如何查看mysql数据库是否进行了增量备份 什么是独立显卡什么事集成显卡 配i54g独立显卡玩lol超级牛逼的配置。 windows下Mysql 怎样备份和还原? 请人回答:集成显卡1G和独立显卡1G区别大吗? 现在最好的独立显卡是几G的 集成显卡比独立显卡的区别真的很大吗? 免费邮箱的邮箱容量及附件大小是多少? 免费邮箱容量大吗?一般有多少容量? 求大容量免费邮箱推荐,谢谢了。 免费189邮箱的容量有多大? 网易邮箱容量有多大?哪个邮箱容量大? 谁知道各个免费邮箱的大小 请问有什么免费邮箱容量比较大,广告比较少呢? 现在哪个免费邮箱容量大?多少? vivo手机为什么无法编辑视频? 163的邮箱容量有多大,怎么把邮箱扩到最大容量? x20不能剪辑视频吗