mysql的主从配置做全备份方法
admin
2023-05-28 20:21:27
0

本文主要给大家介绍mysql的主从配置做全备份方法,希望可以给大家补充和更新些知识,如有其它问题需要了解的可以持续在行业资讯里面关注我的更新文章的。

目的:19 作为 20 的从库

20上做一次全备份

/usr/bin/innobackupex-1.5.1--user=root --password=`cat /etc/savep` --defaults-file=/etc/my.cnf --socket=/tmp/mysql.sock  --slave-info--stream=tar /usr/local/backup | gzip >/usr/local/backup/db20.tar.gz

db20.tar.gz copy 19

--slave-info 保存主库日志文件以及偏移

--stream=tar/usr/local/backup | gzip > /usr/local…压缩方式

[ 在使用参数stream=tar备份的时候,你的xtrabackup_logfile可能会临时放在/tmp目录下,多实例 xtrabackup在备份的时候会生成固定文件/tmp/xtrabackup_logifle,导致互相覆盖。 --tmpdir= ]

mysql的主从配置做全备份方法

19上启动新的实例

  1. 新建/etc/myNew.cnf 注意server id 要跟20不一样 my.cnf server_id xxx

  2. 初始化数据库

3.           scripts/mysql_install_db --user=mysql --datadir=/data/mysqlNew/dataNew  --basedir=/usr/local/mysql

  1. 启动新的实例待会用于做从库

5.           /usr/local/mysql/bin/mysqld_safe --defaults-file=/etc/myNew.cnf --user=mysql &

19上安装 xtrabackup

旧版本5.1

wgethttp://115.182.52.17/software/xtrabackup-1.6.5-328.rhel6.x86_64.rpm

rpm -ivh xtrabackup-1.6.5-328.rhel6.x86_64.rpm  --nodeps (rpm方式安装xtrabackup.)

新版本5.6

wget -O/root/soft/percona-xtrabackup-2.2.11-1.el6.x86_64.rpm

http://115.182.52.17/software/percona-xtrabackup-2.2.11-1.el6.x86_64.rpm

rpm -ivh percona-xtrabackup-2.2.11-1.el6.x86_64.rpm  --nodeps

19上恢复主库的冷备份数据

  1. 解压

2.           mv db20.tar.gz /usr/local/backup/

3.           tar -izxvf db20.tar.gz

这里tar解包必须使用-i参数,否则解压出来的文件只有一个backup-my.cnf

  1. 一般情况下,在备份完成后,数据尚且不能用于恢复操作,因为备份的数据中可能会包含尚未提交的事务或已经提交但尚未同步至数据文件中的事务。因此,此时数据文件仍处理不一致状态。--apply-log的作用是通过回滚未提交的事务及同步已经提交的事务至数据文件使数据文件处于一致性状态。

5.           innobackupex --apply-log . --user=root --password=`cat /etc/savep(不存在密码就不需要这个项)` --defaults-file=/etc/myNew.cnf

  1. 拷贝数据文件

7.           mysqladmin -uroot -S /tmp/mysqlNew.sock shutdown –p 停库删除

8.           cd /data/mysqlNew/dataNew/

9.           rm -rf *

10.       mv /usr/local/backup/* .

11.       chown -R mysql.mysql *

12.       mysqld_safe  --defaults-file=/etc/myNew.cnf --user=mysql &

tail -f log.err 查看是否有报错

进数据库查看数据库是否跟主库一样,

至此已经把20的数据库冷备份恢复到19

启动同步

  1. 确定主库冷备份的的binlog位置

2.           cd /data/mysqlNew/dataNew/

3.           cat xtrabackup_binlog_info  (如果冷备份是从主库直接备份的,则使用这个来确定主库的binlog位置)

4.           或者catxtrabackup_slave_info (如果冷备份是从主库的另外一个从库简介备份的,则使用这个来确定主库的binlog位置)

  1. 进入新实例,新建同步

6.           mysql -uroot -S /tmp/mysqlNew.sock -p

7.           mysql>change master to

8.           -> master_host='10.0.0.20',

9.           ->master_user='re4399pl',

10.       ->master_port=3306,

11.       ->master_password='re4399plpassword',

12.       ->master_log_file='mysql-bin.000006',

13.       ->master_log_pos=110632233;

上面这步需要现在主库上创建帐号

GRANT FILE,SELECT,REPLICATION SLAVE ON*.* TO 're4399pl'@'10.0.0.%'IDENTIFIED BY 're4399plpassword';

master_log_filemaster_log_pos 就是五.1 中的内容

  1. 启动同步

15.       mysql>start slave;

16.       mysql> show slave status\G

17.       如果要重启库,

18.         1mysqladmin –uroot –pxxxx   2,mysqld_safe –user=mysql

其他注意点

  1. 注意多个实例的下的不同data目录和 my.cnf 文件

  2. 从库是不记录Binlog的如果需要做链式同步,从库开启binlog log_slave_updates=1

  3. skip-slave-start 有这个参数,数据库重启后不会自动进行同步

  4. 主从废弃后,应该及时 stop slave reset slave 免得忘记下次又同步

关于同步到从库并过滤部分表的做法

在从库上添加

replicate-wild-do-table=diygame_admin.%

replicate-wild-ignore-table=diygame_online.diygame_game_data%

replicate-wild-do-table=diygame_online.%

同步后重定向到另外一个库

在从库上添加

replicate-wild-do-table=diygame_admin.diygame_template_preview

replicate-wild-do-table=3387_base_admin.%

replicate-rewrite-db=diygame_admin->3387_base_admin

replicate-rewrite-db,及仅能重定向库,不能重定向表,而且还does not workwith cross-database updates

 

十 定时备份


0 0 * * * /cron/db_backup.sh > /tmp/db_backup.log 2>&1
cat /cron/db_backup.sh
#!/bin/bash

PATH=/usr/local/bin:/bin:/usr/bin:/usr/local/mysql/bin:/usr/local/sbin:/usr/sbin:/sbin
DATE=`date +%Y%m%d`
IPADDR=`/sbin/ifconfig em1|grep 'inet addr'|awk '{print $2}'|awk -F ":" '{print $2}'`

passwd=`cat /etc/savep`
NAME=db185_hebi
mkdir /tmp/$NAME
/usr/bin/innobackupex-1.5.1 --user=root --password=`cat /etc/savep` --defaults-file=/etc/my.cnf --slave-info   --tmpdir=/tmp/$NAME/ --stream=tar /usr/local/backup | gzip > /usr/local/backup/$NAME-$DATE-$IPADDR.tar.gz

cd /usr/local/backup/
/usr/local/bin/rsync -R -avz --progress --password-file=/etc/49cn_pass $NAME-$DATE-$IPADDR.tar.gz  49cn@13.7.3.9::49cn/49cn

find /usr/local/backup/ -type f -mtime +7 | xargs rm -f

看了以上关于mysql的主从配置做全备份方法,希望能给大家在实际运用中带来一定的帮助。本文由于篇幅有限,难免会有不足和需要补充的地方,如有需要更加专业的解答,可在官网联系我们的24小时售前售后,随时帮您解答问题的。

相关内容

热门资讯

重新定义信号与频谱分析仪:罗德... 全球测试测量专家罗德与施瓦茨(以下简称“R&S”)宣布,将于6月23日举办 “新一代多通道信号与频谱...
美媒:伊朗军方重建速度远超预期 据美国有线电视新闻网(CNN)报道,两名熟悉美国情报评估的消息人士透露,伊朗已在今年4月初开始的六周...
泰国取消60天免签,是想防着谁... 【文/观察者网专栏作者 岳汉】最近,泰国缩短免签这个事,在国内还引起了挺大关注。很多中国朋友都不解:...
170次要变1万次,马斯克“太... 【文/观察者网 王一】美国企业家马斯克为其旗下太空探索技术公司(SpaceX)制定了一个宏大的目标—...
现在是中国军工进入海湾的新契机... 【文/观察者网专栏作者 晨枫】美以伊战事的走向和终局仍扑朔迷离。长期依赖美国保护伞的海湾国家,其“石...
商务部:中美双方应为双向农产品... 新华社北京5月21日电(记者谢希瑶、何晓)商务部新闻发言人何亚东21日在例行新闻发布会上,回答有关中...
红墙藏旧韵,老厂焕新潮|郑州合... 当城市更新的浪潮邂逅珍贵工业遗存,斑驳红砖墙不再只剩岁月沉淀,更悄然生长出潮流时尚与市井烟火。坐落于...
河南继续雨雨雨模式,警惕持续降... 天气回顾昨天(20日)白天到夜里,河南大部雨水暂歇,仅北部和南部地区出现了分散性阵雨、雷阵雨;不过由...
韩国警方:金秀贤“与未成年人交... 据报道,韩国警方一份记录披露,此前韩国著名演员金秀贤“与未成年交往”系不实消息。韩国首尔江南警察厅已...
海关总署发布支持大湾区建设若干... 今天(21日),海关总署举行新闻发布会,就近日出台的《海关支持粤港澳大湾区建设若干措施》进行解读,从...