评论

收藏

[MySQL] 利用XtraBackup做mysql不停机重做主从复制

数据库 数据库 发布于:2021-07-03 21:40 | 阅读数:459 | 评论:0

  不停机做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;
  

  

  参考链接:
  http://blog.chinaunix.net/uid-20682026-id-3319204.html
  http://wsgzao.github.io/post/xtrabackup/
  

  碰到的问题:
  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/
  执行以上语句,问题即可解决!
  


  
关注下面的标签,发现更多相似文章