Widows下的MYSQL主从复制

  • 需求:服务器上的数据为了安全做一个备份,备份到另外一个服务器数据库中去。

环境

  • 服务器

win10 64位
mysql:8.0.28
端口:3307

  • 本机

win10 64位
mysql:8.0.27
端口:3306

在开始配置之前需要保证自己的服务器可以被ping通

ping 你的公网ip
  • ping不通在云平台添加一个安全组规则
    在这里插入图片描述

在这里插入图片描述

主数据库配置

1. 修改my.ini文件

[mysqld]

port=3307

server-id=1 # 建议1,不要和从数据库相同

log-bin=mysql-bin

binlog_do_db=backup # 要备份的数据库

2. 创建数据库账号,供从库使用

# 创建用户
CREATE USER 'slave'@'%' IDENTIFIED BY '123456';

# 赋予权限
grant all privileges on *.* to 'slave'@'%';

# 刷新权限
FLUSH PRIVILEGES;

保险起见重启mysql

3. 查看主数据库状态

show master status;
  • 执行上面语句后记住下面的FIle 和 Position
+----------------------------+----------+--------------+------------------+-------------------+
| File                       | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+----------------------------+----------+--------------+------------------+-------------------+
| iZbp1i9kk9cqhpZ-bin.000027 |      157 | backup       |                  |                   |
+----------------------------+----------+--------------+------------------+-------------------+

从数据库配置

1. 停止mysql服务

2. 修改my.ini文件

  • [mysqld]下面的server-id不要和主数据库一样就行
server-id=2

replicate-do-db=backup # 指定同步某个数据库

3. 启动mysql服务

4. 设置主从连接信息

  • 如果你之前没启动过从库同步命令,直接输入下面这段命令
CHANGE MASTER TO MASTER_HOST = '主数据库ip地址', MASTER_USER = '主数据库创建的用户',MASTER_PASSWORD = '密码',MASTER_PORT = 3307,MASTER_LOG_FILE='上面记住的File',MASTER_LOG_POS=上面记住的Position不用引号;
  • 如果你之前启动过从库同步命令需要先停止后再输入上面命令
stop slave;
  • 重新启动
start slave;
  • 查看从库状态
show slave status\G
  • 出现下面连接信息就代表你已经完成了配置,可以去同步的数据库内增加表和数据测试一下。

在这里插入图片描述

出现的问题

Got fatal error 1236 from master when reading data from binary log: ‘Could not find first log file name in binary log index file’, Error_code: MY-013114

  • 查看主从状态
Slave_IO_Running: No
Slave_SQL_Running: Yes

解决办法

  • 停止从库同步线程
stop slave;
  • 查看主库状态
mysql> show master status\G;
*************************** 1. row ***************************
             File: mysql-bin.000113
         Position: 276925387
     Binlog_Do_DB: 
 Binlog_Ignore_DB: 
Executed_Gtid_Set: 
1 row in set (0.00 sec)
 
ERROR: 
No query specified
# 刷新日志
flush logs;

# 查看主库状态
show master status;
  • 记住File和Position
  • 切换从库
stop slave;
CHANGE MASTER TO MASTER_LOG_FILE='记住的File',MASTER_LOG_POS=记住的Position;
start slave

Slave_IO_Running: Connecting

  • 请检查域名是否书写正确,以及主机是否ping的通
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值