如何在一台windows主机上搭建mysql主从复制

本文详细介绍了如何通过MySQL配置实现主从复制的过程,包括搭建两个MySQL服务、配置主从节点、创建复制用户、同步数据库状态等步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、首先要在本地建立两个mysql服务(参考这里),指定不同的端口。我这里一个主(3306),一个从(3307)。
2、然后修改主配置文件:
[mysqld]
server-id = 1   
binlog-do-db=test #要同步的数据库
#binlog-ignore-db=mysql   #不同步的数据库,如果指定了binlog-do-db这里应该可以不用指定的
log-bin=mysql-bin #要生成的二进制日记文件名称

修改从配置文件:
[mysqld]
server-id = 2
log-bin    = mysql-bin
replicate-do-db=test
3、在主库添加一个用户 repl 并指定replication权限
create user 'repl'@'127.0.0.1' identified by 'asdf';

GRANT REPLICATION SLAVE ON *.* TO 'repl'@'127.0.0.1'; -- --这里我指定数据库(test.*)时报错,而指定全库(*.*)时会成功。

4、保持主从mysql的test数据库初始状态一致。

一般是先将所有的表加读锁,然后copy磁盘上的数据库文件夹。我这里直接停止服务,然后将数据文件拷贝过去。

5、在主数据库里面运行show master status;记下file和position字段对应的参数。

mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 107 | test | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)

6、在从库设置它的master:

mysql> change master to master_host='127.0.0.1',master_port=3306,master_user='repl',master_password='asdf',master_log_file='mysql-bin.000001',master_log_pos=107;
Query OK, 0 rows affected (0.19 sec)

这里的master_log_file和master_log_pos对应刚才show master status记下的参数。

7、在从库开启从数据库复制功能。

slave start;

mysql> slave start;
Query OK, 0 rows affected (0.00 sec)

在从库可以通过show slave status来查看一些参数。

8. 此时在主库创建表或插入数据,在从库就会很快也能看到了。

-- 主库

mysql> create table tianyc_02(b int);
Query OK, 0 rows affected (0.16 sec)

mysql> insert into tianyc_02 values(2013);
Query OK, 1 row affected (0.13 sec)

-- 从库

mysql> show tables;
+----------------+
| Tables_in_test |
+----------------+
| tianyc_01 |
| tianyc_02 |
+----------------+
2 rows in set (0.00 sec)

mysql> select * from tianyc_02;
+------+
| b |
+------+
| 2013 |
+------+
1 row in set (0.00 sec)

同理,可以搭建第二、第三个从节点。

 

参考:http://blog.sina.com.cn/s/blog_4d06da1f01010m55.html

备注:两个服务的serve_id必须不同,否则在开启复制功能时会提示错误

mysql> slave start;
ERROR 1200 (HY000): The server is not configured as slave; fix in config file or with CHANGE MASTER TO

我这里设置的主节点id为1,从节点id为2。也可以按照ip或端口进行设置,好用来区分。参考这里


 

注意:

     * 主从间的数据库不是实时同步,就算网络连接正常,也存在瞬间,主从数据不一致。 
    * 如果主从的网络断开,从会在网络正常后,批量同步。 
    * 如果对从进行修改数据,那么很可能从在执行主的bin-log时出现错误而停止同步,这个是很危险的操作。所以一般情况下,非常小心的修改从上的数据。

参考:http://bbs.chinaunix.net/thread-2297959-1-1.html


转载地址 :http://www.cnblogs.com/yuechaotian/archive/2013/05/15/3080056.html

### 配置概述 在 Windows 系统上配置 MySQL 主从复制涉及几个关键步骤,包括安装 MySQL、配置主服务器从服务器以及启动复制过程。通过这些操作可实现在多台 MySQL 服务器间的数据同步。 ### 安装 MySQL 确保已成功安装 MySQL 并能正常访问命令行工具[^2]。对于具体版本如 mysql-8.0.15 可将其解压缩到指定文件夹以便分别作为主服务实例 (mysql11) 从服务实例 (mysql12)[^3]。 ### 修改 my.ini 文件 针对每一个 MySQL 实例都需要单独修改 `my.ini` 或者 `my.cnf` 文件来区分不同的服务器 ID: #### Master Server Configuration ```ini [mysqld] server-id=1 log-bin=mysql-bin.log binlog-do-db=testdb ``` #### Slave Server Configuration ```ini [mysqld] server-id=2 relay-log=mysql-relay-bin.log replicate-do-db=testdb ``` 上述配置中,`testdb` 是希望被复制的数据库名称;而 `server-id` 则用于唯一标识每台参与复制链路中的机器[^1]。 ### 初始化并启动 MySQL 服务 利用管理员权限运行 CMD 来初始化数据目录,并以各自的服务名注册两个 MySQL 实例为 Windows Service: ```shell # 对于 master server mysqld --console mysqld.exe -install MySQLMaster --defaults-file="C:\path\to\your\master_my.ini" # 对于 slave server mysqld --console mysqld.exe -install MySQLSlave --defaults-file="C:\path\to\your\slave_my.ini" ``` 接着,在命令提示符窗口里输入 net start 后跟相应服务的名字(即上面定义的服务名),以此方式开启这两个新建立起来的服务[^4]。 ### 设置主从关系 连接至主服务器执行如下 SQL 命令创建具有 REPLICATION SLAVE 特权的新账户供远程登录使用: ```sql CREATE USER 'repl'@'%' IDENTIFIED BY 'password'; GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%'; FLUSH PRIVILEGES; ``` 随后获取当前二进制日志的位置信息: ```sql SHOW MASTER STATUS; ``` 最后切换回从服务器端,按照之前获得的信息调整其指向正确的主机地址及其他必要参数: ```sql CHANGE MASTER TO master_host='IP_of_Master', master_user='repl', master_password='password', master_log_file='recorded_binlog_filename', master_log_pos=recorded_position_value; START SLAVE; ``` 以上便是整个流程的大致描述,实际操作过程中可能还需要根据实际情况做出适当调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值