1912  
查询码: 00000177
Windows下MySQL5.7主从复制的配置
来源:https://www.cnblogs.com/gdjlc/p/12222512.html
作者: 系统管理员 于 2021年03月10日 发布在分类 / 配置安装 / 数据库及SQL脚本 / mysql / 集群 ,于 2021年10月12日 编辑
mysql 主从复制 集群

Windows下MySQL主从复制的配置

MySQL主从复制允许将来自一个数据库(主数据库)的数据复制到一个或多个数据库(从数据库)。 主数据库一般是实时的业务数据写入和更新操作,从数据库常用的读取为主。

MySQL主从复制允许将来自一个数据库(主数据库)的数据复制到一个或多个数据库(从数据库)。
主数据库一般是实时的业务数据写入和更新操作,从数据库常用的读取为主。

主从复制过程:

1、主服务器上面的任何修改都会通过自己的 I/O tread(I/O 线程)保存在二进制日志 Binary log 里面。
2、从服务器上面也启动一个 I/O thread,通过配置好的用户名和密码, 连接到主服务器上面请求读取二进制日志,然后把读取到的二进制日志写到本地的一个Realy log(中继日志)里面。
3、从服务器上面同时开启一个 SQL thread 定时检查 Realy log(这个文件也是二进制的),如果发现有更新立即把更新的内容在本机的数据库上面执行一遍。

环境如下:
主数据库:MySQL版本5.7,IP为192.168.1.11
从数据库:MySQL版本5.7,IP为192.168.1.12

一、主数据库配置

1、创建一个新的测试数据库,名称为testdb。

2、打开my.ini,增加配置

# 主从复制
server-id=1 #设置server-id
log-bin=mysql-bin #开启二进制文件
#同步的数据库,除此之外别的不同步(和下面binlog-ignore-db二选一)
binlog_do_db=testdb
#不同步数据库,除此之外都同步
#binlog-ignore-db = information_schema
#binlog-ignore-db = mysql
配置完成后如下:
[mysqld]
basedir=D:\JavaWorkspace\mysqlGroup\mysql_main\
datadir=D:\JavaWorkspace\mysqlGroup\mysql_main\data\
port=3341
#skip-grant-tables
# 主从复制#设置server-id
server-id=1 
#开启二进制文件
log-bin=mysql-bin 
#同步的数据库,除此之外别的不同步(和下面binlog-ignore-db二选一)
binlog_do_db=wcp
binlog_do_db=wdap
binlog_do_db=ekca
#不同步数据库,除此之外都同步
#binlog-ignore-db = information_schema
#binlog-ignore-db = mysql
[client]   
default-character-set=utf8mb4


3、重启MySQL服务

4、创建用于同步的用户账号
(1)以管理员身份打开cmd窗口后,运行mysql -uroot -p,输入密码(为空则直接回车),登陆。
(2)先后执行下面3条命令创立用户(用户名MySlave,密码123456),并刷新权限


CREATE USER 'MySlave'@'localhost' IDENTIFIED BY '123456';
GRANT REPLICATION SLAVE ON *.* TO 'MySlave'@'localhost';
FLUSH PRIVILEGES;


5、查看Master状态,记录二进制文件名和位置


show master status;


二进制文件为mysql-bin.000005,位置为154

二、从数据库配置

1、创建一个新的测试数据库,名称为testdb。

2、验证同步账号能否登陆
打开Navicat for MySQL,新建链接,IP填写192.168.1.11,用户名MySlave,密码123456,点击“连接测试”验证是否能连接。

3、打开my.ini,增加配置

server-id=2 #设置server-id
log-bin=mysql-bin #开启二进制文件
配置后如下:

[mysqld]
basedir=D:\JavaWorkspace\mysqlGroup\mysql_guest1\
datadir=D:\JavaWorkspace\mysqlGroup\mysql_guest1\data\
port=3342
#skip-grant-tables
#设置server-id
server-id=2 
#开启二进制文件
log-bin=mysql-bin
[client]   
default-character-set=utf8mb4


4、重启MySQL服务

5、cmd命令行登陆MySQL数据库,执行下面命令进行手动同步


mysql > CHANGE MASTER TO MASTER_HOST='192.168.1.11',MASTER_PORT=3306,MASTER_USER='MySlave',MASTER_PASSWORD='123456',MASTER_LOG_FILE='mysql-bin.000005',MASTER_LOG_POS=154;


6、启动salve同步进程


mysql > start slave;


7、查看slave状态
执行命令:show slave status\G;(在navicat客户端执行该命令报错,但是在cmd下的myslq客户端中可以正常执行
Slave_IO_Running: Yes,Slave_SQL_Running: Yes时说明两个线程已启动,主从复制配置成功。

8、测试
在主数据库新建一个表,刷新从数据库,可以看到这个表。


备注:
在进行数据库主从复制前,主数据库中已有表和数据,则这部分数据不会同步,需要手动导出,并在从数据库中导入。


0人参与


 历史版本

备注 修改日期 修改人
格式调整 2021-10-12 13:05:34[当前版本] 系统管理员
格式调整 2021-10-12 13:00:47 系统管理员
格式调整 2021-03-15 18:59:36 系统管理员
格式调整 2021-03-15 18:16:06 系统管理员

 附件

附件类型

PNGPNG

wcp知识库系统-京ICP备15024440号-1 -V 5.2.0 -wcp