mysql使用Percona XtraBackupd在主库不停服的情况下搭建从库

背景:线上环境主库不停服的情况下,使用Percona XtraBackupd工具搭建从库。

环境:主库:192.168.128.132、待搭建从库:192.168.128.135。需要机器:192.168.128.132和192.168.128.135所装的mysql版本需要一致,这里不介绍mysql的安装过程。

开始搭建:

1、机器128.132和128.135,两台机器都安装innobackupex工具,安装连接:

https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.9/binary/redhat/7/x86_64/percona-xtrabackup-24-2.4.9-1.el7.x86_64.rpm

2、主库:128.132上操作,创建用户slave用于从库:128.135复制数据所用:

create user 'slave'@'192.168.128.135' identified BY 'slave_123';  #创建用户:slave,可以从192.168.128.135机器上登录,密码slave_123
grant replication slave on *.*  to 'slave'@'192.168.128.135' identified by 'slave_123';;  #授予用户Slave复制从服务器权限,
flush privileges;  #刷新权限

3、停止待搭建的从库:128.135上的mysql:

service  mysqld  stop   #停止mysql

service  mysqld  status   #查看mysql状态,检查mysql是否关闭

3、移动或清除待搭建的从库:128.135的datadir目录下的全部数据(我这里的数据目录为:/kvm/mysql),可以通过查看/etc/my.cnf来查看datadir路径:

个人建议备份,如果想回退可以移动回来。
移动:
mkdir  /data/dbback  #创建一个dback目录
mv  /kvm/mysql/*  /data/dbback/   #将/kvm/mysql下所有文件移动到/data/dbback目录下

或者清空:
rm  -rf  /kvm/mysql/*

检查/kvm/mysql是否为空(一定要清除干净):
ll /kvm/mysql

 4、主库:128.132不用停服直接备份mysql数据到:128.135上,一般情况下,很多人都是将数据备份到本地,再将数据传输到目标机器上,这样的话会占用本地机器的存储空间,还浪费时间。本次直接将数据备份并直接传输到128.135机器上,不会备份到本地(不占用本地空间),而且是直接传输到128.135机器mysql的datadir路径下,后面也就不用移动了,节省很多步骤:

innobackupex --defaults-file=/etc/my.cnf --use-memory=1G --socket=/tmp/mysql.sock --user=root --password=密码 --stream=xbstream /data/backup/ | ssh 192.168.128.135 'xbstream -x -C /kvm/mysql/' > /dev/null 2>&1

128.132和128.135之间做了免密登录。

上面这个语句,在前台可以跑起来,如果想放到后台执行,可以将语句放入到脚本,然后将脚本放到后台执行。

5、生成的备份文件,还不能用于恢复,先需要对一些未提交的事物需要恢复,恢复redo logo的数据,确保数据的一致,对备份文件执行此操作:

还原备份格式:innobackupex --apply-log  /kvm/mysql/

6、将/kvm/mysql目录及目录以下的所有文件的所有者、所属组改为:mysql:

chown  -R  mysql.mysql  /kvm/mysql/   #-R递归修改/kvm/mysql及目录下所有文件,所有者、所属组都为mysql

7、待搭建的从库:128.135,需要配置/etc/my.cnf文件(需要配置其余选择自行添加):

server_id=135
datadir  =/kvm/mysql/

8、启动新的从库:128.135:

chown  -R  mysql:mysql  /kvm/mysql
chmod  -R  755  /kvm/mysql
service mysqld start  #启动数据库

ps aux | grep mysql #查看进程是否正常启动

8、查看位点信息,在备份时会生成xtrabackup_slave_info文件,xtrabackup_binlog_info文件,这两个文件都记录了主库的MASTER_LOG_FILE和MASTER_LOG_POS信息,便于做主从:

cd   /kvm/mysql/
cat  xtrabackup_info 或者  cat  xtrabackup_binlog_info

有类似信息:CHANGE MASTER TO MASTER_LOG_FILE=‘mysql-bin.000171’,
                            MASTER_LOG_POS=1541514

9、在新从库:128.135、上操作:

从库上配置主库是谁:
change master to master_host = '主库的IP', master_user = '设置主从时设定的主库的用户', master_port=主库的端口, master_password='主库设定的密码', master_log_file = '主库状态的File', master_log_pos=主库状态的Position;

实际代码:CHANGE MASTER TO MASTER_HOST = '192.168.128.132', MASTER_USER = 'slave',  MASTER_PORT = 3306,  MASTER_PASSWORD = 'slave_123',  MASTER_LOG_FILE = 'mysql-bin.000171',  MASTER_LOG_POS = 1541514;

#需要注意,如果有报错,可能是因为binlog文件没有加引号

10、在从库:128.135上开启从库:

start slave;  #开启从库

show slave status \G;   #查看从库状态

注意:如下即为成功,如其中任意一个不为Yes即为失败。
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

当同步失败时,建议从库执行如下命令(清除主从信息),再重新连接主库。
reset slave;
reset slave all;

热备份工具Percona XtraBackupd非常好使用,大家可以试试。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值