以下命令中,只给出某些场景下重要的参数,实际备份多少个库或表,以及是否备份存储过程或触发器之类的,请根据实际情况加对应的参数,这里不列举这类参数。
1.确定备份数据的相关信息
在备份之前,首先要确定备份数据的一些信息,例如表的存储引擎、字符集、时区、是否使用函数存储过程,events与触发器,表大小,当前数据库是否有相关的大SQL等。连接到备份实例,执行如下sql进行查看:
select table_schema,table_name,table_collation,engine,table_rows
from
information_schema.tables where table_schema = ‘your_schema’;
select * from information_schema.EVENTS;
select * from information_schema.ROUTINES;
select * from information_schema.TRIGGERS;
2.单独备份数据
如果只是备份数据,备份文件无需用作建立slave,采用如下方式:
mysqldump -h your_ip -P your_port -u your_user -p \
–default-character-set=your_charset –single-transaction –set-gtid-purged=OFF
3.备份需要建立复制
- 3.1表结构和数据一起备份
mysqldump -h your_ip -P your_port -u your_user -p \
–default-character-set=your_charset –single-transaction –master-data=2- 3.2先备份表结构再备份数据
mysqldump -h your_ip -P your_port -u your_user -p \
–default-character-set=your_charset –single-transaction –no-data
mysqldump -h your_ip -P your_port -u your_user -p \
–default-character-set=your_charset –single-transaction -t