备份mariadb数据库

2020年6月10日 1 207 views 838字阅读2分47秒

主库锁表

flush table with read lock;

备份数据库(会有压缩,测试数据 11G,得到备份文件 227M)

  • 其中 max_allowed_packetnet_buffer_length 两个参数是用来加速的,可以查看从库数据
  • 如果 root 有密码请加上参数例如 -uroot -proot

/usr/local/mariadb/bin/mysqldump --max_allowed_packet=33554432 --net_buffer_length=8192 --events -A -B |gzip >/server/backup/mysql_bak.$(date +%F).sql.gz

PS: 如果上面的命令报错如下

Couldn't execute 'show events': Cannot proceed because system tables used by Event Scheduler were found damaged at server start (1577)

请执行命令(如果 root 有密码请加上参数例如 -uroot -proot )

/usr/local/mariadb/bin/mysql_upgrade

备份结束后,解锁主库,恢复读写

unlock tables;

拷贝到从库中

  • 注意日期一定有所不同,如果端口不是默认的请叫参数 -P 端口号
  • 注意确保 /root 目录有足够的空间,如果空间不够请切换目录
scp /server/backup/mysql_bak.2020-06-04.sql.gz monitor-host02:/root

从库

进入备份文件目录,解压(11G 的库,sql 文件只有 1.2G,注意空间比例)

cd /root
gzip -d mysql_bak.2020-06-04.sql.gz

导入数据

  • 注意始终从库中不可以有写入
  • 请先测试mysql -A是否可以进入数据库
mysql -A < mysql_bak.2020-06-04.sql &

实际上这种方式遇到特别大的数据还是很慢,可以考虑使用xtrabackup来自动备份数据库。

MySQL最后更新:2020-8-31
小熊