阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

XtraBackup实现MySQL不停机重做主从复制

133次阅读
没有评论

共计 2540 个字符,预计需要花费 7 分钟才能阅读完成。

不停机实现 MySQL 主从同步,可以使用 mysqldump,但是这个效率比较低,利用 XtraBackup 来实现这个,效率比较高!

一 xtrabackup 安装:
yum -y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL
rpm -ivh percona-xtrabackup-2.2.12-1.el6.x86_64.rpm

安装 libenv:
wget ftp://rpmfind.net/linux/atrpms/el6-x86_64/atrpms/stable/libev-4.04-2.el6.x86_64.rpm

XtraBackup 软件下载地址:
软件下载地址:https://www.percona.com/software/mysql-database/percona-xtrabackup

二 核对 mysql 的版本:
利用 xtrabackup 做全备和恢复的,Mysql 的版本最好一致!
检查 mysql 版本:
 /webser/mysql55/bin/mysql -V
/webser/mysql55/bin/mysql  Ver 14.14 Distrib 5.5.21, for Linux (x86_64) using readline 5.1
三. 在 master 服务器上在线备份数据库:
innobackupex –defaults-file=/webser/mysql55/etc/my.cnf –user=root –password=xxxx  /tmp/

备份指定的数据库:
innobackupex –defaults-file=/webser/mysql55/etc/my.cnf –user=root –password=xxxxx –include=’abc.*|salt.*’  /tmp/

注意多个库之间用“|”符号隔开!

PS:/tmp/ 为备份目录;
然后通过 scp 方式把 master 上

四.slave 机器上操作;
1)关闭 mysql 服务;
然后清空 mysql 数据目录下文件,例如本机 mysql 的数据目录是:/webser/mysql55/var/

2)开始恢复数据
假设备份文件的路径在:/tmp/2016-04-29_16-00-54

恢复日志文件:
innobackupex –defaults-file=/webser/mysql55/etc/my.cnf –user=root –password=xxxx –apply-log /tmp/2016-04-29_16-00-54/
恢复数据文件:
innobackupex –defaults-file=/webser/mysql55/etc/my.cnf –user=root –password=xxxx –copy-back /tmp/2016-04-29_16-00-54/

3)修改数据目录权限:
chown -R mysql:mysql /webser/mysql55/var 
4)安全方式启动 mysql,查看是否有异常;
/webser/mysql55/bin/mysqld_safe –defaults-file=/webser/mysql55/etc/my.cnf &
如果没有异常报错,就关闭 mysql
 /webser/mysql55/bin/mysqladmin -uroot -p shutdown

5)查看 binlog 日志文件的位置值,做主从同步:
cat /tmp/2016-04-29_16-00-54/xtrabackup_binlog_info
wwwmaster.000458    1022022953
6)在 slave 机器上做主从相关操作:
CHANGE MASTER TO
MASTER_HOST=’192.168.3.xxx’,
MASTER_USER=’mysql_rep’,
MASTER_PASSWORD=’xxxx’,
MASTER_PORT=33066,
MASTER_LOG_FILE=’wwwmaster.000458′,
MASTER_LOG_POS=1022022953;
启动主从同步:
start slave;

碰到的问题:
1)启动后报错:
[root@GuoletaoTest02 etc]# /etc/init.d/mysql55 start
Starting MySQL (Percona Server)…The server quit without u[FAILED]PID file (/data/mysql55/var/GuoletaoTest02.pid).
查看错误日志:
160429 16:47:12 [ERROR] Can’t open the mysql.plugin table. Please run mysql_upgrade to create it.
解决办法:
 ./mysql_install_db –user=mysql –basedir=/webser/mysql55/ –datadir=/data/mysql55/var/
执行以上语句,问题即可解决!

MySQL 管理之使用 XtraBackup 进行热备 http://www.linuxidc.com/Linux/2014-04/99671.htm

MySQL 开源备份工具 Xtrabackup 备份部署 http://www.linuxidc.com/Linux/2013-06/85627.htm

MySQL Xtrabackup 备份和恢复 http://www.linuxidc.com/Linux/2011-12/50275.htm

用 XtraBackup 实现 MySQL 的主从复制快速部署【主不锁表】http://www.linuxidc.com/Linux/2012-10/71919p2.htm

安装和使用 Percona 推出的 Xtrabackup 备份 MySQL http://www.linuxidc.com/Linux/2011-10/44451.htm

XtraBackup 的详细介绍:请点这里
XtraBackup 的下载地址:请点这里

本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-04/130852.htm

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-22发表,共计2540字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中