使用rsync建立MySQL从节点

使用场景:MySQL主节点存储较大,使用xtrabackup会遇到异常的情况

前置条件:node-01 与 node-02 做过ssh互信,rsync客户端均已安装,主节点开启binlog

node-01 原主节点,数据存放目录为 /var/lib/mysql

node-02 新建从节点,数据存放目录为 /var/lib/mysql

一、数据复制

  1. node-01上运行使用rsync先传输一份数据副本(数据一致性不保证),用于rsync增量追平,选择非业务忙阶段
shell 复制代码
# 保证 node-02 数据目录为空
export KBPS=5000 # 5MB/s
ssh node-02 "rm -rf /var/lib/mysql"
rsync -avP -e "ssh" /var/lib/mysql/  node-02:/var/lib/mysql  --bwlimit=${KBPS}
  1. 业务低峰运行,需要添加FTWRD实例级别读锁
shell 复制代码
# 加锁
mysql -uroot -p$MYSQL_ROOT_PASSWORD -e "flush tables with read lock;select sleep(28000)" &
# 去掉限速,尽快追平数据
rsync -avP -e "ssh" /var/lib/mysql/  node-02:/var/lib/mysql  --delete

# 再运行,确认和上一次运行的输出一致则为获取到一致性数据
rsync -avP -e "ssh" /var/lib/mysql/  node-02:/var/lib/mysql  --delete

# 获取 FTWRD 的 PID
FTWRD_PID=$(ps -aux |  grep mysql | grep flush | awk '{print $2}')

kill  $FTWRD_PID

二、主库为传统模式

登录到node-02,通过binlog获取主节点的position值,当node-02节点上的数据是node-01上的镜像,所以在node-02解析出来的位点信息也是一样的

shell 复制代码
# 获取最近的 binlog 文件名
ls mysql-bin.0* | sort -r | head -n 1

# 获取最新的位点信息
mysqlbinlog --base64-output=decode-rows   mysql-bin.000970 > target.sql
grep "end_log_pos"  target.sql  | tail -n 1 >point.txt
cat point.txt

保证从节点的server-id 与主节点不一致

shell 复制代码
sed -e "#s#server-id=1#server-id=13#g" /etc/my.cnf

删除当前的server的uuid 重启后自动生成新的

shell 复制代码
rm -f /var/lib/mysql/auto.cnf

开启从MySQL实例,登录到从MySQL执行

sql 复制代码
CHANGE MASTER TO MASTER_HOST='node-01',	MASTER_PORT=3306, MASTER_USER='repl',MASTER_PASSWORD='xxxxx',MASTER_LOG_FILE='mysql-bin.000970',MASTER_LOG_POS={point.txt中的位点信息};

start slave;
show slave status\G

三、主库开启了GTID

登录到node-02,保证从节点的server-id 与主节点不一致

shell 复制代码
sed -e "#s#server-id=1#server-id=13#g" /etc/my.cnf

删除当前的server的uuid 重启后自动生成新的

shell 复制代码
rm -f /var/lib/mysql/auto.cnf

开启从MySQL实例,登录到从MySQL执行

sql 复制代码
CHANGE MASTER TO MASTER_HOST='node-01',	MASTER_PORT=3306, MASTER_USER='repl',MASTER_PASSWORD='xxxxx',MASTER_LOG_POS=1;

start slave;
show slave status\G
相关推荐
mygljx1 小时前
MySQL 数据库连接池爆满问题排查与解决
android·数据库·mysql
Bdygsl2 小时前
MySQL(1)—— 基本概念和操作
数据库·mysql
身如柳絮随风扬2 小时前
什么是左匹配规则?
数据库·sql·mysql
jiankeljx3 小时前
mysql之如何获知版本
数据库·mysql
小李来了!3 小时前
数据库DDL、DML、DQL、DCL详解
数据库·mysql
我科绝伦(Huanhuan Zhou)4 小时前
【生产案例】MySQL InnoDB 数据损坏崩溃修复
数据库·mysql·adb
海棠蚀omo5 小时前
从零敲开 MySQL 的大门:库与表的基础操作实战(保姆级入门指南)
数据库·mysql
廋到被风吹走5 小时前
【MySql】超时问题分析
java·数据库·mysql
y = xⁿ5 小时前
重生之我创作出了小红书:对象存储模块,用户资料模块
后端·mysql·intellij-idea
Y001112365 小时前
Day10-MySQL-事物
数据库·sql·mysql