主从复制(windows单机上实现,多个端口)(十)

本文介绍如何在单台Windows电脑上通过不同端口配置实现Redis主从复制,包括配置多个实例作为Master和Slave,调整配置文件以实现读写分离,及验证复制效果。

现在开始主从复制,需求肯定是多台电脑是最好能模拟的,但是受限于资金和电脑(本人电脑是windows),只能在一台电脑上进行模拟主从复制了,https://blog.youkuaiyun.com/m0_38129920/article/details/84104779我是根据这个博客来自己做的一些步骤,并说出自己做的时候的一些问题,当然大家也可以直接按上面博客的来,我实践过,没有问题,就是有可能想法有一些区别所以自己在做的时候会碰壁

我是让端口为6380的为Master,端口号为6381,6382的为Slave

1.复制redis.windows-service.conf文件,并改名成对应的端口redis-6380.conf,redis-6381.conf,redis-6382.conf

在这里插入图片描述
上面三个redis-6380.conf,redis-6381.conf,redis-6382.conf是自己复制的redis-windows.server.conf改的别名
复制后分别在这三个conf里修改配置

第一处地方

在这里插入图片描述
改端口,改成6380或者6381或者6382(三个conf都要改)
如果你的redis有密码限制的话
在这里插入图片描述

第二处地方对生成的log文件命名更改

在这里插入图片描述
改这个地方,看到这就应该明白了,最开始的下部分那三个txt文件不需要我们自己去建,让系统自己去建,自己只需要让conf执行就行了

第三处地方

在这里插入图片描述
记住这个更改的是Slave端口需要修改的,Master端口不用修改(如果修改了就没Master了),
这个的意思是:这个端口是哪个端口的Slave机

第四处地方

在这里插入图片描述
这个是Slave 需要打开的就是Slave是只能读,不能写,默认是yes,所以基本上不用改

第五处地方

关闭Master的AOF和RDB(Slave开启了,那Master就不用开启了)
在这里插入图片描述
在这里插入图片描述
记住关闭的是Master的,Slave还是要开的
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
现在做的主从是下面这个图的模样
在这里插入图片描述
当然为了防止产生复制风暴可能就需要让上图的Master的上面再接个Master,它自己由Master变为Slave
这个不是重点,稍微一提,那就先看看自己配置成功的结果吧

2.分别启动三个节点

在这里插入图片描述
上面这三张图形象的说明了这一点我就不解释了,后面的操作这三个窗口不要关闭,要不关哪个端口,哪个端口就关闭

查看端口的信息用

redis-cli.exe -p 6380 "info"  //info查看详细信息

会出来很多信息
在这里插入图片描述
这个就说明你配置成功了。当前端口为Master,还有两个端口(6381,6382)为Slave
当然也可以看看Slave的信息

redis-cli.exe -p 6381 "info"

在这里插入图片描述
它们还是有很大的区别的

下面测试主从节点。

那三个端口开着,可以再开两个cmd.exe,一个操作Master,一个操作Slave
在Master的操作

D:\redis>redis-cli.exe -p 6380   //进入Master,
127.0.0.1:6380> keys * //查看所有的key
(empty list or set)
127.0.0.1:6380> set mykey "55555"  //添加数据
OK
127.0.0.1:6380> 

在Slave的操作

C:\Users\lenovo>redis-cli -p 6381  //进入Slave
127.0.0.1:6381> keys *  //获取全部key
1) "mykey"
127.0.0.1:6381> get mykey  //获得key为mykey的值
"55555"
127.0.0.1:6381> set my 666  //slave添加数据
 //只允许Slave读,不允许写,这样可以有效读写分离,分担压力
(error) READONLY You can't write against a read only slave. 

默认情况下,slave节点是只读的,可以从slave节点的info信息中可以看出。 slave_read_only:1,表示slave是只读的。

<think>我们首先需要确定在Windows下安装MySQL的步骤,然后配置主从复制。根据用户需求,我们推荐使用MySQL 8.0版本,因为它是当前最新的稳定版本,具有较好的性能和安全性。 步骤概述: 1. 下载并安装MySQL 8.0(主库和从库分别安装,或者在同一台机器上安装两个实例) 2. 配置主库(修改配置文件、创建复制账户、授权等) 3. 配置从库(修改配置文件、设置主库信息、启动复制等) 4. 验证主从复制 注意:在Windows上,我们可以通过安装两个MySQL实例(使用不同的端口)来实现主从复制。 详细步骤: 一、下载和安装MySQL 8.0 1. 下载MySQL 8.0社区版 访问MySQL官方网站:https://dev.mysql.com/downloads/installer/ 选择MySQL Installer for Windows,下载后运行安装程序。 2. 安装主库(默认端口3306) 在安装过程中,选择“Server only”安装类型。 配置步骤: - 选择“Standalone MySQL Server / Classic MySQL Replication” - 选择“Config Type”为“Development Computer”(根据实际需要选择) - 设置root密码 - 添加一个具有管理员权限的用户(可选) - 设置Windows服务名(如:MySQL80_Master) - 确保启用开机自启动(可选) 3. 安装从库(端口3307) 在安装第二个实例(从库)时,我们可以使用同一安装程序,但选择“Replication Slave”作为功能,或者手动配置第二个实例。 但是,MySQL Installer通常用于安装一个实例。因此,我们可以通过命令行方式安装第二个实例: a. 复制主库的安装目录(例如:C:\Program Files\MySQL\MySQL Server 8.0)到另一个目录(例如:C:\MySQL_Slave) b. 创建新的数据目录(例如:C:\MySQL_Slave\data) c. 初始化从库实例: mysqld --initialize-insecure --basedir="C:\MySQL_Slave" --datadir="C:\MySQL_Slave\data" d. 安装Windows服务(注意服务名和配置文件): mysqld install MySQL80_Slave --defaults-file="C:\MySQL_Slave\my.ini" e. 在my.ini配置文件中设置端口、数据目录等(下面会详细说明) 或者,更简单的方法:使用MySQL Installer安装一个实例作为主库,然后使用同样的安装程序再安装一个实例(选择自定义安装,只安装MySQL Server),并指定不同的端口和服务名。 二、主库配置(端口3306) 1. 修改主库配置文件(my.ini) 默认位置:C:\ProgramData\MySQL\MySQL Server 8.0\my.ini 在[mysqld]部分添加或修改以下参数: ```ini [mysqld] # 主库配置 server-id = 1 log-bin = mysql-bin # 启用二进制日志 binlog_format = ROW # 推荐使用ROW格式 # 指定要复制的数据库(可选,不指定则复制所有数据库) # binlog-do-db = mydb # 设置日志过期时间 expire_logs_days = 7 max_binlog_size = 100M ``` 2. 重启主库服务 在服务管理器中重启MySQL80_Master服务(或使用命令:net stop MySQL80_Master 然后 net start MySQL80_Master) 3. 创建复制账户并授权 登录主库MySQL: mysql -u root -P3306 -p 执行SQL: CREATE USER 'repl'@'%' IDENTIFIED BY 'YourPassword123!'; GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'repl'@'%'; FLUSH PRIVILEGES; 4. 查看主库状态,记录File和Position SHOW MASTER STATUS; 输出示例: +------------------+----------+--------------+------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | +------------------+----------+--------------+------------------+ | mysql-bin.000001 | 155 | | | +------------------+----------+--------------+------------------+ 三、从库配置(端口3307) 1. 修改从库配置文件(my.ini) 如果是独立安装的从库,配置文件可能在C:\ProgramData\MySQL\MySQL Server 8.0\my.ini(如果是复制安装,则修改从库的my.ini) 在[mysqld]部分添加: ```ini [mysqld] server-id = 2 # 必须唯一,不能和主库相同 relay-log = mysql-relay-bin # 启用中继日志 read_only = ON # 从库设置为只读(可选,但推荐) ``` 2. 重启从库服务 在服务管理器中重启MySQL80_Slave服务 3. 配置复制链路 登录从库MySQL: mysql -u root -P3307 -p 执行: CHANGE MASTER TO MASTER_HOST='localhost', # 如果主库在另一台机器,则填写主库IP MASTER_PORT=3306, MASTER_USER='repl', MASTER_PASSWORD='YourPassword123!', MASTER_LOG_FILE='mysql-bin.000001', # 这里填写主库状态中的File MASTER_LOG_POS=155; # 这里填写主库状态中的Position 4. 启动复制 START SLAVE; 5. 检查复制状态 SHOW SLAVE STATUS\G 查看以下两个字段: Slave_IO_Running: Yes Slave_SQL_Running: Yes 如果都是Yes,则表示复制正常运行。 四、测试主从复制 在主库上创建一个数据库或表,插入数据,然后在从库上查看是否同步。 注意:如果主库已经有数据,需要先备份主库并导入从库,然后再配置复制(步骤中省略了,因为新安装的数据库没有数据)。如果有数据,参考引用[4]中的备份恢复步骤。 推荐版本:MySQL 8.0.33(当前最新GA版本) 以上步骤适用于Windows环境。注意防火墙设置,确保主从库之间的端口(3306和3307)是开放的。 相关问题: 1. 如何解决Windows下安装多个MySQL实例时的端口冲突? 2. MySQL主从复制中常见错误有哪些?如何解决? 3. 如何监控MySQL主从复制的延迟? 4. 在Windows下如何自动启动多个MySQL实例?</think>### Windows 下 MySQL 下载安装及主从复制配置指南 **推荐版本:MySQL 8.0.33(长期支持版,稳定且兼容性强)** --- ### 一、MySQL 下载与安装(Windows) #### 1. 下载步骤 1. 访问 [MySQL 官网](https://dev.mysql.com/downloads/installer/) 2. 选择 **MySQL Installer for Windows**(推荐下载 `mysql-installer-web-community-8.0.33.msi`) 3. 若需离线安装,下载 `mysql-installer-community-8.0.33.msi`(约400MB) #### 2. 安装流程 ```powershell # 以管理员身份运行安装程序,按以下步骤操作: 1. 选择安装类型: [Custom](自定义安装) 2. 添加产品: - MySQL Server 8.0.33 - MySQL Shell(可选,管理工具) - MySQL Router(可选,高可用工具) 3. 配置实例: - 主库: 端口 3306,服务名 `MySQL80_Master` - 从库: 端口 3307,服务名 `MySQL80_Slave`(需独立安装) 4. 认证方式: - 选择 "Use Strong Password Encryption"(推荐) 5. 设置 root 密码: 如 `MasterRoot123!`(主库)、`SlaveRoot123!`(从库) 6. 完成安装: 勾选 "Start MySQL Server at Startup"(开机自启) ``` > **注意**:若需单机模拟主从,需安装**两个独立实例**(不同端口和服务名)[^3]。 --- ### 二、主库配置(端口 3306) #### 1. 修改配置文件 `my.ini` ```ini [mysqld] # 主库标识(必须唯一) server-id = 1 # 二进制日志配置 log-bin = "C:/ProgramData/MySQL/MySQL Server 8.0/Data/mysql-bin" binlog_format = ROW # 同步指定数据库(可选) binlog-do-db = mydb # 日志保留策略 expire_logs_days = 7 max_binlog_size = 100M ``` > 文件路径:`C:\ProgramData\MySQL\MySQL Server 8.0\my.ini` > 修改后重启服务:`net stop MySQL80_Master && net start MySQL80_Master` #### 2. 创建复制账户并授权 ```sql -- 登录主库 mysql -uroot -P3306 -p -- 创建账户(限制从库IP) CREATE USER 'repl'@'192.168.1.100' IDENTIFIED WITH mysql_native_password BY 'ReplPass123!'; -- 授予复制权限 GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'repl'@'192.168.1.100'; -- 刷新权限 FLUSH PRIVILEGES; -- 查看主库状态(记录 File 和 Position) SHOW MASTER STATUS; ``` > 输出示例: > | File | Position | > |---------------|----------| > | mysql-bin.0001 | 785 | [^3] --- ### 三、从库配置(端口 3307) #### 1. 修改配置文件 `my.ini` ```ini [mysqld] server-id = 2 # 区别于主库 relay-log = "C:/ProgramData/MySQL/MySQL Server 8.0/SlaveData/relay-bin" read_only = ON # 从库只读 ``` #### 2. 配置主从链路 ```sql -- 登录从库 mysql -uroot -P3307 -p -- 设置主库信息(使用 SHOW MASTER STATUS 获取的值) CHANGE MASTER TO MASTER_HOST = '192.168.1.100', -- 主库IP MASTER_USER = 'repl', MASTER_PASSWORD = 'ReplPass123!', MASTER_PORT = 3306, MASTER_LOG_FILE = 'mysql-bin.0001', MASTER_LOG_POS = 785, MASTER_CONNECT_RETRY = 10; -- 启动复制 START SLAVE; -- 检查复制状态 SHOW SLAVE STATUS\G ``` > **关键状态验证**: > - `Slave_IO_Running: Yes` > - `Slave_SQL_Running: Yes` > - `Seconds_Behind_Master: 0`(表示无延迟)[^4] --- ### 四、主从复制验证测试 | 操作步骤 | 命令示例 | 预期结果 | |--------------------------|------------------------------|------------------------------| | 1. 主库创建测试数据库 | `CREATE DATABASE mydb;` | | | 2. 主库创建表并插入数据 | `USE mydb; CREATE TABLE t(id INT); INSERT INTO t VALUES(1);` | | | 3. 从库检查数据同步 | `SELECT * FROM mydb.t;` | 应返回 `id=1` 的记录 | --- ### 五、关键注意事项 1. **防火墙配置**: ```powershell # 开放主从通信端口 netsh advfirewall firewall add rule name="MySQL Replication" dir=in action=allow protocol=TCP localport=3306-3307 ``` 2. **数据一致性**: - 若主库已有数据,需先用 `mysqldump` 备份并导入从库[^4]: ```powershell mysqldump -uroot -P3306 --master-data=2 --databases mydb > backup.sql mysql -uroot -P3307 < backup.sql ``` 3. **故障排查**: - 复制中断时检查 `Last_IO_Error` 和 `Last_SQL_Error` - 重新同步:`STOP SLAVE; RESET SLAVE; START SLAVE;` --- ### 版本推荐理由 | 版本 | 特点 | |---------------|----------------------------------------------------------------------| | **MySQL 8.0** | 支持窗口函数、JSON增强、原子DDL,性能提升30%[^1] | | MySQL 5.7 | 已停止官方支持(EOL),仅适用于旧系统兼容 | > 通过以上步骤,可实现每秒数万次的事务同步,延迟控制在毫秒级[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值