MySQL单机改主从——binlog同步方式

1.实施前提

主库需要开启binlog(value为on即为开启)

show variables like 'log_bin';

主库需要开启gtid模式(value为on即为开启)

show variables like 'gtid_mode';

从库需要安装好与主库版本一致

2.主从实施

2.1主库上创建复制用户

复制代码
GRANT REPLICATION SLAVE ON *.* to 'repl'@'192.168.53.%' IDENTIFIED BY 'repl';

2.2对主库进行备份

复制代码
mysqldump -uroot -p123123 --single-transaction --master-data=2 --A --triggers --routines --events | gzip > fulldb_backup.sql.gz
  • 使用 mysqldump 进行全库备份,包含触发器、存储过程、函数和事件。
  • --single-transaction 保证数据一致性。
  • --master-data=2 包含主从复制信息。

2.3恢复从库数据

gzip -d fulldb_backup.sql.gz

mysql -uroot -p < fulldb_backup.sql

2.4建立主从复制关系

通过less等工具查看备份文件头部fulldb_backup.sql

找到一行如下:

-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000021', MASTER_LOG_POS=844124729;

将在备份文件中找到的MASTER_LOG_FILE,MASTER_LOG_POS写入命令中,登录到从库执行

复制代码
CHANGE MASTER TO MASTER_HOST='192.168.53.199',MASTER_PORT=3306,MASTER_USER='repl',MASTER_PASSWORD='repl',MASTER_LOG_FILE='mysql-bin.000021',MASTER_LOG_POS=844124729;

3.启动slave进程,状态验证

登录从库

start slave;

show slave status\G;

相关推荐
GottdesKrieges43 分钟前
OceanBase租户扩缩容的三种方法
数据库·oceanbase
IvanCodes44 分钟前
MySQL 窗口函数
数据库·sql·mysql
Android 小码峰啊5 小时前
Android Compose 层叠布局(ZStack、Surface)源码深度剖析(14)
android
清霜之辰5 小时前
Android Compose 中 Side Effects 和 State 相关的 API 使用
android·state·compsoe·side effects
coding侠客7 小时前
MySQL事务隔离级别的实现原理MVCC
数据库·mysql·mvcc·事务隔离级别·事务四大特性
liujun-blog7 小时前
SQL经典实例
数据库·sql
草药味儿の岁月7 小时前
MySQL 高级查询:JOIN、子查询、窗口函数
数据库·mysql
深山技术宅8 小时前
mysql主从复制搭建,并基于‌Keepalived + VIP实现高可用
mysql·高可用·主从复制
橘猫云计算机设计8 小时前
基于springboot的金院银行厅预约系统的设计及实现(源码+lw+部署文档+讲解),源码可白嫖!
java·数据库·spring boot·后端·爬虫·spring·毕业设计
5178 小时前
pymysql
java·数据库·oracle