MySQL主从复制配置-windows单机环境

本文详细介绍了如何在Windows 8.1系统下配置MySQL 5.6.16版本的主从复制环境。包括搭建master和slave服务器、配置相关参数、创建复制用户以及解决常见问题等步骤。
windows8.1系统下配置mysql主从复制
1.测试环境概述
  本地win8操作系统,64位操作系统,3G内存,下载的是mysql5.6.16-winx64.zip包
  在本地磁盘上解压两个mysql,端口分别是3310和3311,即:
  localhost:3310   --master服务器
  localhost:3311   --slave服务器

2.配置master
  将压缩包解压: C:/software/mysql-5.6.16-winx64-3310
  在这个目录下建立tmp文件夹
  在该目录下新增my.ini文件,其内容如下:
# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/5.6/en/server-configuration-defaults.html
# *** DO NOT EDIT THIS FILE. It's a template which will be copied to the
# *** default location during install, and will be replaced if you
# *** upgrade to a newer version of MySQL.
[mysqld]
server-id=1
#replicate-same-server-id=0
# Remove leading # and set to the amount of RAM for the most important data
# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
# innodb_buffer_pool_size = 128M
# Remove leading # to turn on a very important data integrity option: logging
# changes to the binary log between backups.
# log_bin
# These are commonly set, remove the # and set as required.
basedir = C:/software/mysql-5.6.16-winx64-3310
datadir = C:/software/mysql-5.6.16-winx64-3310/data
tmpdir = C:/software/mysql-5.6.16-winx64-3310/tmp
port = 3310
log-bin=master-bin
log-bin-index=master-bin.index
#default-character-set = utf8
# server_id = .....
# Remove leading # to set options mainly useful for reporting servers.
# The server defaults are faster for transactions and fast SELECTs.
# Adjust sizes as needed, experiment to find the optimal values.
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
[client]
port = 3310
#default-character-set = utf8
其中,server-id变量表示该节点在集群内的唯一表示,每个节点必须使用不同的server-id来区分
basedir,datadir,tmpdir这些表示的是数据文件或临时文件的存放路径,因为我们在一台机器上创建2个mysql数据库服务,为了两个实例之间的数据不发生干扰,我们在配置文件中明确指定其位置
port:这个参数就是mysql服务的监听端口,这里我们设置的是3310
log-bin:要将服务器设置为master,需要确保该服务器有一个活动的二进制日志(binary log),该日志上保留了服务器上的所有改变,并且这些改变可以在slave上被重新执行
3.启动master
命令行切换到 C:\software\mysql-5.6.16-winx64-3310\bin(master解压目录),执行mysqld --console命令,得如下信息,则master启动完毕:
C:\software\mysql-5.6.16-winx64-3310\bin>mysqld --console
2014-03-26 22:20:48 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
2014-03-26 22:20:48 7204 [Note] Plugin 'FEDERATED' is disabled.
2014-03-26 22:20:48 7204 [Note] InnoDB: Using atomics to ref count buffer pool pages
2014-03-26 22:20:48 7204 [Note] InnoDB: The InnoDB memory heap is disabled
2014-03-26 22:20:48 7204 [Note] InnoDB: Mutexes and rw_locks use Windows interlocked functions
2014-03-26 22:20:48 7204 [Note] InnoDB: Compressed tables use zlib 1.2.3
2014-03-26 22:20:48 7204 [Note] InnoDB: Not using CPU crc32 instructions
2014-03-26 22:20:48 7204 [Note] InnoDB: Initializing buffer pool, size = 128.0M
2014-03-26 22:20:48 7204 [Note] InnoDB: Completed initialization of buffer pool
2014-03-26 22:20:48 7204 [Note] InnoDB: Highest supported file format is Barracuda.
2014-03-26 22:20:48 7204 [Note] InnoDB: 128 rollback segment(s) are active.
2014-03-26 22:20:48 7204 [Note] InnoDB: Waiting for purge to start
2014-03-26 22:20:48 7204 [Note] InnoDB: 5.6.16 started; log sequence number 1625977
2014-03-26 22:20:49 7204 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: d440636c-b4f1-11e3-9ec4-904ce5e379cc.
2014-03-26 22:20:49 7204 [Note] Server hostname (bind-address): '*'; port: 3310
2014-03-26 22:20:49 7204 [Note] IPv6 is available.
2014-03-26 22:20:49 7204 [Note] - '::' resolves to '::';
2014-03-26 22:20:49 7204 [Note] Server socket created on IP: '::'.
2014-03-26 22:20:50 7204 [Note] Event Scheduler: Loaded 0 events
2014-03-26 22:20:50 7204 [Note] mysqld: ready for connections.
Version: '5.6.16-log' socket: '' port: 3310 MySQL Community Server (GPL)
4.在master上创建一个复制用户
4.1修改默认的root密码
如果是已有的数据库则该步骤,则修改密码部分省略
C:/software/mysql-5.6.16-winx64-3310\mysqladmin -uroot password 111111
通过如上命令,我们给默认的root帐号一个密码111111
4.2添加复制用户并给予权限:
C:/software/mysql-5.6.16-winx64-3310 \mysql -uroot -p111111
进入到mysql数据库中
mysql> create user repl_user;
Query OK, 0 rows affected (0.00 sec)
mysql>
mysql> grant replication slave on *.* to repl_user identified by '111111';
Query OK, 0 rows affected (0.00 sec)
mysql>
replication slave这个权限没有什么特别之处,只是这个用户可以从master上取得二进制的日志转储数据,完全可以给一个常规帐号赋予replication slave权限,但是最好还是将replication slave权限和其他用户权限分开,这样的话,如果后期想禁止某些slave的链接,只要删除该用户就可以了
5.配置slave
  将压缩包解压: C:/software/mysql-5.6.16-winx64-3311
  在这个目录下建立tmp文件夹
  在该目录下新增my.ini文件,其内容如下:
# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/5.6/en/server-configuration-defaults.html
# *** DO NOT EDIT THIS FILE. It's a template which will be copied to the
# *** default location during install, and will be replaced if you
# *** upgrade to a newer version of MySQL.
[mysqld]
server-id=2
#replicate-same-server-id=0
# Remove leading # and set to the amount of RAM for the most important data
# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
# innodb_buffer_pool_size = 128M
# Remove leading # to turn on a very important data integrity option: logging
# changes to the binary log between backups.
# log_bin
# These are commonly set, remove the # and set as required.
basedir = C:/software/mysql-5.6.16-winx64-3311
datadir = C:/software/mysql-5.6.16-winx64-3311/data
tmpdir = C:/software/mysql-5.6.16-winx64-3311/tmp
port = 3311
relay-log = slave-relay-bin
relay-log-index = slave-relay-bin.index
#default-character-set = utf8
# server_id = .....
# Remove leading # to set options mainly useful for reporting servers.
# The server defaults are faster for transactions and fast SELECTs.
# Adjust sizes as needed, experiment to find the optimal values.
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
[client]
port = 3311
#default-character-set = utf8
与master一样,slave也要配置一个唯一的服务器id,relay-log和relay-log-index表示中继日志文件和中继日志索引文件
6.启动slave
命令行切换到 C:\software\mysql-5.6.16-winx64-3311\bin(slave解压目录),执行mysqld --console命令,得如下信息,则slave启动完毕:
C:\software\mysql-5.6.16-winx64-3311\bin>mysqld --console
2014-03-26 22:21:19 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
2014-03-26 22:21:19 6916 [Note] Plugin 'FEDERATED' is disabled.
2014-03-26 22:21:19 6916 [Note] InnoDB: Using atomics to ref count buffer pool pages
2014-03-26 22:21:19 6916 [Note] InnoDB: The InnoDB memory heap is disabled
2014-03-26 22:21:19 6916 [Note] InnoDB: Mutexes and rw_locks use Windows interlocked functions
2014-03-26 22:21:19 6916 [Note] InnoDB: Compressed tables use zlib 1.2.3
2014-03-26 22:21:19 6916 [Note] InnoDB: Not using CPU crc32 instructions
2014-03-26 22:21:19 6916 [Note] InnoDB: Initializing buffer pool, size = 128.0M
2014-03-26 22:21:19 6916 [Note] InnoDB: Completed initialization of buffer pool
2014-03-26 22:21:19 6916 [Note] InnoDB: Highest supported file format is Barracuda.
2014-03-26 22:21:20 6916 [Note] InnoDB: 128 rollback segment(s) are active.
2014-03-26 22:21:20 6916 [Note] InnoDB: Waiting for purge to start
2014-03-26 22:21:20 6916 [Note] InnoDB: 5.6.16 started; log sequence number 1625977
2014-03-26 22:21:20 6916 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: e6f98904-b4f1-11e3-9ec5-904ce5e379cc.
2014-03-26 22:21:20 6916 [Note] Server hostname (bind-address): '*'; port: 3311
2014-03-26 22:21:20 6916 [Note] IPv6 is available.
2014-03-26 22:21:20 6916 [Note] - '::' resolves to '::';
2014-03-26 22:21:20 6916 [Note] Server socket created on IP: '::'.
2014-03-26 22:21:21 6916 [Note] Event Scheduler: Loaded 0 events
2014-03-26 22:21:21 6916 [Note] mysqld: ready for connections.
Version: '5.6.16' socket: '' port: 3311 MySQL Community Server (GPL)
7.将slave连接到master上
现在创建基本的复制只剩最后一步了:将slave指向master,让它知道从哪里进行复制,为此你需要知道master的4个信息:主机名,主机端口号,主机数据库用户,主机数据库帐号密码,因为创建master的时候已经创建了一个复制用户,因此在slave节点上执行如下指令:
mysql> change master to master_host='localhost',master_port=3310,master_user='repl_user',master_password='111111';
Query OK, 0 rows affected, 2 warnings (0.45 sec)
mysql>
mysql> start slave;
Query OK, 0 rows affected (0.05 sec)
mysql>
8.常见问题排查
执行如上命令后,输出如下信息:
2014-03-26 23:11:23 6916 [ERROR] Slave I/O: error connecting to master 'repl_user@localhost:3310' - retry-time: 60 retries: 1, Error_code: 1045
这个说明slave和master之间的链接没有建立成功,这个时候多半是添加了新用户repl_user后,没有生效导致
在master上执行flush privileges;来将新建的用户及权限生效
<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. 创建复制账户并授权 登录主库MySQLmysql -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. 配置复制链路 登录从库MySQLmysql -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>### WindowsMySQL 下载安装及主从复制配置指南 **推荐版本: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、付费专栏及课程。

余额充值