Windows2012系统安装mysql8.0.20INSTALLER主从复制

本文详细介绍了如何在Mysql数据库中配置半同步主从架构模式,包括安装配置过程、远程连接设置、主从复制账户创建、以及半同步插件的安装与启用步骤。

(因为本人目前已经有一套已经配置完成的mysql集群架构,所以本人需要先将目前集群内的cak数据库做个dump备份一下再把现在的集群给删除重新做 ‘可惜了现在的环境,要配置好久’ );
先把需要的数据库给备份:
备份我的cak库
在这里插入图片描述
使用 mysqldump命令备份cak数据库
mysqldump -u[用户名] -p[密码] [数据库名] > [保存的路径和保存的备份名]
在这里插入图片描述
在这里插入图片描述
我现在将我的cak库已经保存到了D盘内的文件夹中。

目前的主从是正常的:
在这里插入图片描述

在这里插入图片描述
现在的IO和SQL状态都是YES,证明我的主从是正常的状态,现在把环境全部重新做,给数据库卸载掉。

安装数据库

开始新装INSTALLER安装包数据库:

在这里插入图片描述
选择server服务:
在这里插入图片描述
在这里插入图片描述
在线更新下载组件
在这里插入图片描述
点击Execute
在这里插入图片描述
在这里插入图片描述
默认点击两次Next进入到配置页面:
进入选择默认
在这里插入图片描述
development主机:
在这里插入图片描述
选择设置密码方式:
在这里插入图片描述
设置密码
在这里插入图片描述
一路下一步
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
可以看到日志里的信息,和已经成功安装完成后显示的finish按钮。
查看一下我默认的安装路径有没有mysql文件夹:
我的是在C盘下
在这里插入图片描述
查看一下是否有安装后的组件
在这里插入图片描述
查看一下ProgramData下有没有INSTALLER版本的配置文件
在这里插入图片描述
在这里插入图片描述
这个my文件需要我们用到主从的配置,先让我们打开mysql做一些远程的配置
打开DOS界面开启一下mysql服务,开启的mysql服务名是刚刚上面安装的时候设置的默认的mysql80服务名(自定义的服务名就输入自己的服务名)
在这里插入图片描述
服务已经启动,在开始里找到mysql的命令窗口进入mysql配置:
在这里插入图片描述
输入配置的密码登陆mysql
在这里插入图片描述
在这里插入图片描述
查看目前数据库内的所有库实例

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
4 rows in set (0.01 sec)

mysql>

切换进mysql库实例内

mysql> use mysql;
Database changed
mysql>

查看user表内容:

mysql> show tables;
+---------------------------+
| Tables_in_mysql           |
+---------------------------+
| columns_priv              |
| component                 |
| db                        |
| default_roles             |
| engine_cost               |
| func                      |
| general_log               |
| global_grants             |
| gtid_executed             |
| help_category             |
| help_keyword              |
| help_relation             |
| help_topic                |
| innodb_index_stats        |
| innodb_table_stats        |
| password_history          |
| plugin                    |
| procs_priv                |
| proxies_priv              |
| role_edges                |
| server_cost               |
| servers                   |
| slave_master_info         |
| slave_relay_log_info      |
| slave_worker_info         |
| slow_log                  |
| tables_priv               |
| time_zone                 |
| time_zone_leap_second     |
| time_zone_name            |
| time_zone_transition      |
| time_zone_transition_type |
| user                      |
+---------------------------+
33 rows in set (0.04 sec)

mysql> select user,host from user;
+------------------+-----------+
| user             | host      |
+------------------+-----------+
| mysql.infoschema | localhost |
| mysql.session    | localhost |
| mysql.sys        | localhost |
| root             | localhost |
+------------------+-----------+
4 rows in set (0.00 sec)

mysql>

可以看到里面有root用户,但是只能够local登陆,需要将其更改为全部登陆方式


mysql> update user set host='%' where user='root';
Query OK, 1 row affected (0.08 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> select user,host from user;
+------------------+-----------+
| user             | host      |
+------------------+-----------+
| root             | %         |
| mysql.infoschema | localhost |
| mysql.session    | localhost |
| mysql.sys        | localhost |
+------------------+-----------+
4 rows in set (0.00 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.03 sec)

mysql>

查看一下防火墙的端口3306是否开启
在这里插入图片描述
这里我用本机的Navicat测试是否能够连接数据库
在这里插入图片描述
到此,远程连接是正常的。

配置主从

下面就开始配置我们的主从数据库:
到上面的my文件位置打开my文件,修改里面的server id等数
server-id=1 (数值往前为主,数值往后为从)
以下根据实际需要自行配置:
max_connections=15100
tmp_table_size=116M
innodb_log_file_size=128M
max_allowed_packet=1G

主服务器配置复制账户:

mysql> create user 'master_user'@'%' identified WITH 'mysql_native_password' by
'123456';
Query OK, 0 rows affected (0.07 sec)

mysql> grant all privileges on *.* to 'master_user'@'%' with grant option;
Query OK, 0 rows affected (0.10 sec)

mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.01 sec)

mysql> show master status\G;
*************************** 1. row ***************************
             File: WIN-NI46FVCM674-bin.000003
         Position: 847
     Binlog_Do_DB:
 Binlog_Ignore_DB:
Executed_Gtid_Set:
1 row in set (0.00 sec)

ERROR:
No query specified

mysql> use mysql;
Database changed
mysql> select user,host from user;
+------------------+-----------+
| user             | host      |
+------------------+-----------+
| master_user      | %         |
| root             | %         |
| mysql.infoschema | localhost |
| mysql.session    | localhost |
| mysql.sys        | localhost |
+------------------+-----------+
5 rows in set (0.00 sec)

mysql>

打开从服务器(安装与配置与以上配置相同)
查看一下slave状态:
输入 show slave status\G;

Slave_IO_Running: No
Slave_SQL_Running: No

change主服务器的复制账户:

mysql> CHANGE MASTER TO 
MASTER_HOST='(主服务器IP地址)', 
MASTER_USER='master_user',
MASTER_PASSWORD='123456', 
MASTER_LOG_FILE='WIN-NI46FVCM674-bin.000003(刚才查看的master服务器file文件号)', 
MASTER_LOG_POS=847(刚才查看的master服务器position号);
Query OK, 0 rows affected, 1 warning (0.04 sec)

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

mysql> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: (主服务器IP地址)
                  Master_User: master_user
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: WIN-NI46FVCM674-bin.000003
          Read_Master_Log_Pos: 847
               Relay_Log_File: WIN-ESCN1RS3ISI-relay-bin.000002
                Relay_Log_Pos: 334
        Relay_Master_Log_File: WIN-NI46FVCM674-bin.000003
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB:
          Replicate_Ignore_DB:
           Replicate_Do_Table:
       Replicate_Ignore_Table:
      Replicate_Wild_Do_Table:
  Replicate_Wild_Ignore_Table: cak.sty_access_event,cak.sty_access_event_his,cak
.sty_access_event_pool,cak.sty_access_json_pool,cak.sty_device_master_cmd,cak.st
y_access_data,cak.sty_site_card,cak.sty_site_card_del,cak.sty_site_card_to_maste
r,cak.sty_site_card_to_master_saved,cak.sty_system_event,cak.sty_system_state,ca
k.sty_system_log
                   Last_Errno: 0
                   Last_Error:
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 847
              Relay_Log_Space: 553
              Until_Condition: None
               Until_Log_File:
                Until_Log_Pos: 0
           Master_SSL_Allowed: No
           Master_SSL_CA_File:
           Master_SSL_CA_Path:
              Master_SSL_Cert:
            Master_SSL_Cipher:
               Master_SSL_Key:
        Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error:
               Last_SQL_Errno: 0
               Last_SQL_Error:
  Replicate_Ignore_Server_Ids:
             Master_Server_Id: 1
                  Master_UUID: 02e5884e-b9d4-11ea-a694-902b34ce9dae
             Master_Info_File: mysql.slave_master_info
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: Slave has read all relay log; waiting for more up
dates
           Master_Retry_Count: 86400
                  Master_Bind:
      Last_IO_Error_Timestamp:
     Last_SQL_Error_Timestamp:
               Master_SSL_Crl:
           Master_SSL_Crlpath:
           Retrieved_Gtid_Set:
            Executed_Gtid_Set:
                Auto_Position: 0
         Replicate_Rewrite_DB:
                 Channel_Name:
           Master_TLS_Version:
       Master_public_key_path:
        Get_master_public_key: 0
            Network_Namespace:
1 row in set (0.00 sec)

ERROR:
No query specified

mysql>

可以看到,到此,主从已经成功。
(测试是否可用可以随个人意愿,插入一些数据创建一些数据存储来查看一下从库的数据复制)。

安装配置半同步插件

已经完成了数据库的主从同步配置之后,默认的数据库复制模式是异步数据库复制模式(不管从库是否能够完整接收到主库传输的数据,只要主库自身传输完所有数据,就会终止传输。),这种模式数据传输快,但是数据 不完整性概率很大,所以配置半同步复制(多集群服务器情况下,一个从库完整接收主库的数据传输后即返回cak确认消息完成复制)。

1.查看目前的插件状态:

在这里插入图片描述

安装主从插件

在Windows系统下的Mysql半同步插件后缀名为.dll文件(不要搞错或者找不着):
主从插件的路径在mysql配置目录lib\plugin下
在这里插入图片描述

配置插件

主库插件

mysql> install plugin rpl_semi_sync_master soname 'semisync_master.dll';
Query OK, 0 rows affected (0.08 sec)

mysql> select PLUGIN_NAME,PLUGIN_STATUS
    -> from information_schema.plugins where PLUGIN_NAME like '%semi%';
+----------------------+---------------+
| PLUGIN_NAME          | PLUGIN_STATUS |
+----------------------+---------------+
| rpl_semi_sync_master | ACTIVE        |
+----------------------+---------------+
1 row in set (0.01 sec)

mysql> show variables like '%semi%';
+-------------------------------------------+------------+
| Variable_name                             | Value      |
+-------------------------------------------+------------+
| rpl_semi_sync_master_enabled              | OFF        |
| rpl_semi_sync_master_timeout              | 10000      |
| rpl_semi_sync_master_trace_level          | 32         |
| rpl_semi_sync_master_wait_for_slave_count | 1          |
| rpl_semi_sync_master_wait_no_slave        | ON         |
| rpl_semi_sync_master_wait_point           | AFTER_SYNC |
+-------------------------------------------+------------+
6 rows in set, 1 warning (0.00 sec)

mysql>

可以看到主库的semi插件处于OFF状态,等一下再开启主库的ON状态。

从库插件

mysql> install plugin rpl_semi_sync_slave soname 'semisync_slave.dll';

查看从库的插件状态:

mysql> select PLUGIN_NAME,PLUGIN_STATUS
    -> from information_schema.plugins where PLUGIN_NAME like '%semi%';
+---------------------+---------------+
| PLUGIN_NAME         | PLUGIN_STATUS |
+---------------------+---------------+
| rpl_semi_sync_slave | ACTIVE        |
+---------------------+---------------+
1 row in set (0.01 sec)

mysql> show variables like '%semi%';
+---------------------------------+-------+
| Variable_name                   | Value |
+---------------------------------+-------+
| rpl_semi_sync_slave_enabled     | OFF   |
| rpl_semi_sync_slave_trace_level | 32    |
+---------------------------------+-------+
2 rows in set, 1 warning (0.01 sec)

mysql>

将semi半同步插件启用

将rpl_semi_sync_slave_enabled 的OFF状态更改成ON状态:

mysql> show variables like '%semi%';
+-------------------------------------------+------------+
| Variable_name                             | Value      |
+-------------------------------------------+------------+
| rpl_semi_sync_master_enabled              | OFF        |
| rpl_semi_sync_master_timeout              | 10000      |
| rpl_semi_sync_master_trace_level          | 32         |
| rpl_semi_sync_master_wait_for_slave_count | 1          |
| rpl_semi_sync_master_wait_no_slave        | ON         |
| rpl_semi_sync_master_wait_point           | AFTER_SYNC |
+-------------------------------------------+------------+
6 rows in set, 1 warning (0.00 sec)

mysql> set global rpl_semi_sync_master_enabled = 1;
Query OK, 0 rows affected (0.00 sec)

mysql> show variables like '%semi%';
+-------------------------------------------+------------+
| Variable_name                             | Value      |
+-------------------------------------------+------------+
| rpl_semi_sync_master_enabled              | ON         |
| rpl_semi_sync_master_timeout              | 10000      |
| rpl_semi_sync_master_trace_level          | 32         |
| rpl_semi_sync_master_wait_for_slave_count | 1          |
| rpl_semi_sync_master_wait_no_slave        | ON         |
| rpl_semi_sync_master_wait_point           | AFTER_SYNC |
+-------------------------------------------+------------+
6 rows in set, 1 warning (0.01 sec)

mysql>

同理,将从库的OFF状态也变成ON状态:

mysql> show variables like '%semi%';
+---------------------------------+-------+
| Variable_name                   | Value |
+---------------------------------+-------+
| rpl_semi_sync_slave_enabled     | ON    |
| rpl_semi_sync_slave_trace_level | 32    |
+---------------------------------+-------+
2 rows in set, 1 warning (0.01 sec)

查看master状态:

mysql> show status like '%semi%';
+--------------------------------------------+-------+
| Variable_name                              | Value |
+--------------------------------------------+-------+
| Rpl_semi_sync_master_clients               | 0     |
| Rpl_semi_sync_master_net_avg_wait_time     | 0     |
| Rpl_semi_sync_master_net_wait_time         | 0     |
| Rpl_semi_sync_master_net_waits             | 0     |
| Rpl_semi_sync_master_no_times              | 0     |
| Rpl_semi_sync_master_no_tx                 | 0     |
| Rpl_semi_sync_master_status                | ON    |
| Rpl_semi_sync_master_timefunc_failures     | 0     |
| Rpl_semi_sync_master_tx_avg_wait_time      | 0     |
| Rpl_semi_sync_master_tx_wait_time          | 0     |
| Rpl_semi_sync_master_tx_waits              | 0     |
| Rpl_semi_sync_master_wait_pos_backtraverse | 0     |
| Rpl_semi_sync_master_wait_sessions         | 0     |
| Rpl_semi_sync_master_yes_tx                | 0     |
+--------------------------------------------+-------+
14 rows in set (0.01 sec)

查看slave状态:

mysql> show status like '%semi%';
+----------------------------+-------+
| Variable_name              | Value |
+----------------------------+-------+
| Rpl_semi_sync_slave_status | OFF   |
+----------------------------+-------+
1 row in set (0.01 sec)

mysql>

从库的状态还是异步复制状态,并没有启用半同步复制状态,此时需要先重启一下从库上的I/O线程

mysql> stop slave io_thread;
Query OK, 0 rows affected (0.01 sec)

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

mysql> show status like '%semi%';
+----------------------------+-------+
| Variable_name              | Value |
+----------------------------+-------+
| Rpl_semi_sync_slave_status | ON    |
+----------------------------+-------+
1 row in set (0.00 sec)

半同步复制已经启用。
下面可以由小伙伴们增加数据来做测试啦。

<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]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值