暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Mysqldump备份与恢复

糖颂元明清彡 2020-03-23
252

1、     查看Mysqldump的参数

-A:--all databases 所有数据库备份

-B:指定多个数据库备份 增加建库语句及use语句

--compact 减少无用输出---去掉备份文件中注释的SQL语句,适合调试,生产中不建议使用

-F 刷新binlog日志,生产新文件,将来增量从这个新文件开始(完整恢复=全备+临界点binlog)

--master-data 增加binlog日志文件名及对应的位置点(有锁表功能)(即CHANGE MASTER 语句)

--master-data=1 不注释可执行

--master-data=2 注释信息(

-x 是锁表,为什么要锁表?主要是确保备份数据的完整性,不要出现“锯齿状”数据,尽量在业务低谷时备份或内部专门用于备份的从数据库 在锁表

-l 对所有表加读锁。(默认是打开的,用--skip-lock-tables来关闭,上面的选项会把关闭-l选项)

-d 只备份库表结构无数据

-t 只备份数据无表结构 SQL语句形式

-T 库表,数据分离不同文件,数据是文本形式、

--single-transaction  适合InnoDB数据数据库备份,它有Acid 特性,隔离性:执行dump后,只能看到之前的数据,之后插入的被隔离

-q, --quick 直接导出不写入内存        Don't buffer query,dump directly to stdout.

##快速               (Defaults to on; use--skip-quick to disable.)

--single-transaction 备份期间不锁表,又能保证数据一致性(基于innodb引擎),例如给每个人照相,“快照”

-S 多实例指定socket

出现events—warning,下面是 处理方法:

这是因为mysqldump默认是不备份事件表的,只有加了--events 才会,解决办法:

加上--events 或 --ignore-table=mysql.events 参数即可;

   #导出事件      #忽略某个表的意思,可以mysqldump --help 查看

mysqldump -uroot -poldboy123 -S/data/3307/mysql.sock  --events  -A >all.sql

-B的“增加建库语句”作用

如果没有-B这个参数 备份文件中就不会有如下内容,在恢复的时候不会有建库的动作

2、     备份演习


2.1在test数据库创建student表

MySQL [(none)]> create database test;Query OK, 1 row affected (0.00 sec)


MySQL [(none)]> use test;
Database changed
MySQL [test]> create table student(
-> id int(4) not null,
-> name char(20) not null,
-> age tinyint(2) NOT NULL default '0',
-> dept varchar(16) default NULL
-> );
Query OK, 0 rows affected (0.02 sec)


MySQL [test]> show tables;
+----------------+
| Tables_in_test |
+----------------+
| student |
+----------------+
1 row in set (0.00 sec)


MySQL [test]> desc student;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id | int(4) | NO | | NULL | |
| name | char(20) | NO | | NULL | |
| age | tinyint(2) | NO | | 0 | |
| dept | varchar(16) | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
4 rows in set (0.01 sec)


MySQL [test]>
复制

2.2备份数据库test

[root@iz2ze4aweqtt2k1ycaxxmmz mysql]# mysqldump -uroot –p密码 -B test > /test/mysql/test_bak.sql
[root@iz2ze4aweqtt2k1ycaxxmmz mysql]# ll
total 4
-rw-r--r-- 1 root root 2007 Mar 23 12:45 test_bak.sql
复制

2.3删除test数据库

MySQL [(none)]> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| ccnet-db |
| mysql |
| nextcloud_db |
| owncloud |
| performance_schema |
| seafile-db |
| seahub-db |
| sys |
| test |
| wordpress |
| zabbix |
+--------------------+
12 rows in set (0.00 sec)


MySQL [(none)]> drop database test;
Query OK, 1 row affected (0.01 sec)


MySQL [(none)]> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| ccnet-db |
| mysql |
| nextcloud_db |
| owncloud |
| performance_schema |
| seafile-db |
| seahub-db |
| sys |
| wordpress |
| zabbix |
+--------------------+
11 rows in set (0.00 sec)


MySQL [(none)]>
复制

2.4恢复数据库

[root@iz2ze4aweqtt2k1ycaxxmmz mysql]# mysql -uroot -p密码 < /test/mysql/test_bak.sql
MySQL [(none)]> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| ccnet-db |
| mysql |
| nextcloud_db |
| owncloud |
| performance_schema |
| seafile-db |
| seahub-db |
| sys |
| test |
| wordpress |
| zabbix |
+--------------------+
12 rows in set (0.00 sec)


MySQL [(none)]> use test;
Database changed
MySQL [test]> show tables;
+----------------+
| Tables_in_test |
+----------------+
| student |
+----------------+
1 row in set (0.00 sec)


MySQL [test]> desc student;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id | int(4) | NO | | NULL | |
| name | char(20) | NO | | NULL | |
| age | tinyint(2) | NO | | 0 | |
| dept | varchar(16) | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)


MySQL [test]>
复制

然后我们发现数据库恢复成功了

这样我们就不用跑路了。

文章转载自糖颂元明清彡,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论