一、mysqldump的简单介绍
mysqldump是MySQL原生自带的逻辑备份,单线程工具。
mysqldump 相当于一个MySQL客户端工具,你的服务器在远程,mysqldump在本地,没有任何问题,也就意味着二者可以在不同的主机上。
mysqldump 可实现完全备份和部分备份,但是还原一个库时,这个库得事先存在,就是说在还原前,先得CREATE DATABASE。
适用场景:一次性dump备份的数据量在10G以下
对本机执行备份(通过本地socket连接,速度较快)
# mysqldump -u root -p"MySQL@123" --single-transaction --routines --triggers --events test > test.sql
# mysqldump -u root -h localhost -p"MySQL@123" --single-transaction --routines --triggers --events test > test.sql
对远端服务器执行备份(通过TCP协议连接,速度一般)
# mysqldump -u root -h xx.xx.xx.xx -p"MySQL@123" --single-transaction --routines --triggers --events test > test.sql
# mysqldump --help
#################################################
-h 主机
-P端口
-u用户名
-p密码 (注意不能有空格)
--ignore-table 忽略表不到出 举例 ----ignore-table=dataname.table1 --ignore-table=dataname.table2
-d 结构(--no-data:不导出任何数据,只导出数据库表结构)
-t 数据(--no-create-info:只导出数据,而不添加CREATE TABLE 语句)
-n (--no-create-db:只导出数据,而不添加CREATE DATABASE 语句)
-R (--routines:导出存储过程以及自定义函数)
-E (--events:导出事件)
--triggers (默认导出触发器,使用--skip-triggers屏蔽导出)
-B (--databases:导出数据库列表,单个库时可省略)
--tables 表列表(单个表时可省略)
①同时导出结构以及数据时可同时省略-d和-t
②同时 不 导出结构和数据可使用-ntd
③只导出存储过程和函数可使用-R -ntd
④导出所有(结构&数据&存储过程&函数&事件&触发器)使用-R -E(相当于①,省略了-d -t;触发器默认导出)
⑤只导出结构&函数&事件&触发器使用 -R -E -d
#######################################################
二、备份与还原
数据导出
备份单个库
# mysqldump -u root -p"MySQL@123" --single-transaction --routines --triggers --events test > test.sql
还原单个库(恢复时如果目标库不存在,需要事先手动创建)
# mysql -u root -p"MySQL@123" -e "create database if not exists test default character set utf8 collate utf8_general_ci;"
# mysql -u root -p"MySQL@123" -D test < test.sql
备份单个库的某张表(registry库中的role表)
# mysqldump -u root -p"MySQL@123" --single-transaction --routines --triggers --events registry role > registry_role.sql
# mysql -u root -p"MySQL@123" -D registry < registry_role.sql
可以看出,指定数据库进行备份的这种方式,它只是备份这个库里的东西,它以为这个库是事先存在的,所以恢复时是不会自动创建库的。
备份多个库
# mysqldump -u root -p"MySQL@123" --single-transaction --routines --triggers --events --databases A B > AB.sql
还原多个库(恢复时,无需事先创建库)
# mysql -u root -p"MySQL@123" < AB.sql
MySQL的全库备份
# mysqldump -u root -p"MySQL@123" --single-transaction --routines --triggers --events --all-databases > all.sql
默认情况下,来自具有GTID的服务器的部分转储将包括所有事务的GTID,甚至是那些更改了数据库的已抑制部分的事务。
如果您不想恢复GTID,请传递 --set-gtid-purged = OFF, 要进行完整转储,请传递 --all-databases --triggers --routines --events。
表结构导出
导出单个库中的所有表结构
# mysqldump -u root -p"MySQL@123" --single-transaction --routines --triggers --events --no-data registry > registry_frm.sql
导出单个库中的单个表结构
# mysqldump -u root -p"MySQL@123" --single-transaction --routines --triggers --events --no-data registry role > registry.role_frm.sql
导出多个库中的所有表结构
# mysqldump -u root -p"MySQL@123" --single-transaction --routines --triggers --events --no-data --databases A B > AB_frm.sql
三、参考
MySQL的全库备份
https://www.jianshu.com/p/bdda49562cf9
MySQL 中 localhost 127.0.0.1 区别
https://jin-yang.github.io/post/mysql-localhost-vs-127.0.0.1-introduce.html
Linux在shell中日期格式化
https://blog.csdn.net/shanliangliuxing/article/details/16821175
https://stackoverflow.com/questions/1401482/yyyy-mm-dd-format-date-in-shell-script
MySQL 备份和恢复机制
https://juejin.im/entry/5a0aa2026fb9a045132a369f
常用MySQL图形化管理工具
https://blog.csdn.net/weixin_34401479/article/details/85777674
基于mysqldump做备份恢复
https://jkzhao.github.io/2018/04/21/%E5%9F%BA%E4%BA%8Emysqldump%E5%81%9A%E5%A4%87%E4%BB%BD%E6%81%A2%E5%A4%8D
MySQL存储引擎对比
https://jkzhao.github.io/2018/04/08/MySQL%E5%AD%98%E5%82%A8%E5%BC%95%E6%93%8E%E5%AF%B9%E6%AF%94