设为首页 收藏本站
查看: 596|回复: 0

[经验分享] Mysql数据库的备份

[复制链接]

尚未签到

发表于 2018-10-4 10:34:47 | 显示全部楼层 |阅读模式
1.mysqldump mysqldump 是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,也是最常用的备份方法。  备份:mysqldump -uroot -p 数据库名 > /root/数据库名.sql
  恢复数据库:首先得先创建:create database 数据库名;
  mysql -uroot -p 数据库名 < /root/数据库名.sql
或者 mysql>Source /root/数据库名.sql例如:mysqldump -uroot -p mydb > /root/mydb.sql      mysql>create database mydb;  mysql -uroot -p mydb < /root/mydb.sql
  或者 source /root/mydb.sql
  常见选项:
  mysqldump -uroot -p --all-databases (备份所有数据库)> /root/mysql.sql
--compatible=name 它告诉 mysqldump,导出的数据将和哪种数据库或哪个旧版本的 MySQL 服务器相兼容  --complete-insert,-c
  导出的数据采用包含字段名的完整 INSERT 方式,也就是把所有的值都写在一行
  --default-character-set=charset
  指定导出数据时采用何种字符集,如果数据表不是采用默认的 latin1 字符集的话,那么
  导出时必须指定该选项,否则再次导入数据后将产生乱码问题。
  --extended-insert = true|false
  默认情况下,mysqldump 开启 --complete-insert 模式,因此不想用它的的话,就使用本选项,
  设定它的值为 false 即可。
  --hex-blob
  使用十六进制格式导出二进制字符串字段。如果有二进制数据就必须使用本选项。影响到的字
  段类型有 BINARY、VARBINARY、BLOB。
  --lock-all-tables,-x
  在开始导出之前,提交请求锁定所有数据库中的所有表,以保证数据的一致性。这是一个全局读锁,
  并且自动关闭 --single-transaction 和 --lock-tables 选项。
  --lock-tables
  它和 --lock-all-tables 类似,不过是锁定当前导出的数据表,而不是一下子锁定全部库下
  的表。本选项只适用于 MyISAM 表,如果是 Innodb 表可以用 --single-transaction 选项。
  --no-create-info,-t
  只导出数据,而不添加 CREATE TABLE 语句。
  --no-data,-d
  不导出任何数据,只导出数据库表结构。
  --quick,-q
  该选项在导出大表时很有用,它强制 mysqldump 从服务器查询取得记录直接输出而不是取得所有记录后将它们缓存到内存中。
  --routines,-R
  导出存储过程以及自定义函数。
  --single-transaction
  该选项在导出数据之前提交一个 BEGIN SQL语句,BEGIN 不会阻塞任何应用程序且能保证导出时数据库的一致性状态。它只适用于事务表,例如 InnoDB 和 BDB。
  --triggers
  同时导出触发器。该选项默认启用,用 --skip-triggers 禁用它
  例如:使用以下 SQL 来备份 MyISAM 表:
  mysqldump -uroot -p123 \
  --default-character-set=utf8 --opt --extended-insert=false \
  --triggers -R --hex-blob -x db_name > db_name.sql
  使用以下 SQL 来备份 Innodb 表:
  mysqldump -uroot -p123 \
  --default-character-set=utf8 --opt --extended-insert=false \
  --triggers -R --hex-blob --single-transaction db_name > db_name.sql
  实现在线备份,还可以使用 --master-data 参数来实现:
  mysqldump -uroot -p123 \
  --default-character-set=utf8 --opt --master-data=1 \
  --single-transaction --flush-logs db_name > db_name.sql
  2.select inito outfile  只针对某一个表或某一个表中的数据进行备份
  备份:mysql> use mydb;
  mysql>show tables;
  mysql>select * inio outfile '/tmp/stu.sql' from stu;
  恢复:mysql>TRUNCATE  TABLE stu;(删除表)
  mysql>LOAD DATA INFILE '/tmp/stu.sql' INTO TABLE stu;
  注意:SELECT * INTO OUTFILE '/tmp/db_name/tbl_name.txt' FROM tbl_name;
  必须要有 FILE 权限才能执行本SQL,并且文件 /tmp/db_name/tbl_name.txt 必须能被 mysqld 用户可写,导出的文件不能覆盖已经存在的文件,以避免安全问题
3.mk-parallel-dump 实现并行备份,mysqldump是单进程的,同时只能备份1个表。mk-parallel-dump它会同时并发4个mysqldump进程,同时备份4个表,默认是先备份大表,  在备份小表。和mysqldump出来生成一个文件不同,它将每个表生成一个单独的文件。
  mk-parallel-dump --basedir=/backups
  mk-parallel-restore /backups
  
4.snapshot 使用快照备份snapshot备份原理:LVM snapshot的原理是当一个snapshot创建的时候,仅拷贝原始卷里数据的元数据(meta-data)。创建的时候,并不会有数据的物理拷贝,因此snapshot的创建几乎是实时的,当原始卷上有写操作执行时,snapshot跟踪原始卷块的改变,这个时候原始卷上将要改变的数据在改变之前被拷贝到snapshot预留的空间里,因此这个原理的实现叫做写时复制(copy-on-write)。在写操作写入块之前,将原始数据移动到 snapshot空间里,这样就保证了所有的数据在snapshot创建时保持一致。而对于snapshot的读操作,如果是读取数据块是没有修改过的,那么会将读操作直接重定向到原始卷上,如果是要读取已经修改过的块,那么就读取拷贝到snapshot中的块。lvcreate -L 10G -n mydata vg0      创建逻辑卷mkfs.ext3 /dev/vg0/mydata          格式化mount /dev/vg0/mydata  /home/mysql  挂载到/home/mysqllvcreate -L 1G -n mydatasnap -s vg0  做快照备份5.mysqlhotcopymysqlhotcopy 是一个 PERL 程序它使用 LOCK TABLES、FLUSH TABLES 和 cp 或 scp 来快速备份数据库。它是备份数据库或单个表的最快的途径,但它只能运行在数据库文件(包括数据表定义文件、数据文件、索引文件)所在的机器上。mysqlhotcopy 只能用于备份 MyISAM,并且只能运行在 类Unix 和 NetWare 系统上。  备份之前最好将数据库中的表LOCK
  mysql> LOCK TABLE stu READ; (锁定stu表)
  mysql>UNLOCK TABLES stu; (解开表)
  mysqlhotcopy  mydb /tmp
  mysqlhotcopy --method=scp mydb \user@backup.company.com:/backup (远程备份)
  恢复备份:cp -rf mydb /usr/local/mysql/data
  chown -R nobody:nobody /usr/local/mysql/data/ (将 db_name 目录的属主改成 mysqld 运行用户)
  时间点恢复:mysqlbinlog --start-position 15000(上次完全备份之后开始位置) --end-position 20000 (用户做误删除之前的位置)| mysql -uroot -p
  mysqlbinlog --start-position 15000 --end-position 20000 > /tmp/bin.sql
  mysql -uroot -p < /tmp/bin.sql
  
  6.ibbackup
  相比MYSQL自身的MYSQLDUMP 导入导出工具来说有以下优点:
  物理备份;还原速度快。
  而MYSQLDUMP在并发小的时候还可以用下。缺点如下:
逻辑备份;还原速度慢。  备份:/ibbackup --apply-log backup.cnf
  整个的还原过程是:
  1.先停掉MYSQLD。
  2.COPY这些文件到现网的MySQL数据以及日志目录。
  2.再次启动MYSQLD。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-611766-1-1.html 上篇帖子: MySQL 的主从复制 下篇帖子: mysql 慢查询说明
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表