当前位置: 首页 > news >正文

Windows 上设置 MySQL 的主从复制

Windows 上设置 MySQL 的主从复制

  • 一、前言
    • 1. 环境准备
    • 2. 主服务器配置
    • 3. 从服务器配置
    • 6. 测试复制
    • 7. 注意事项


一、前言

在 Windows 上设置 MySQL 的主从复制涉及几个步骤。下面是一个详细的指南,帮助你实现这一过程。

1. 环境准备

  1. 安装 MySQL
    确保你在 Windows 上安装了 MySQL,并且能够访问 MySQL 命令行工具。

  2. 确定主从服务器
    假设我们有两台机器:

    • 主服务器(Master):192.168.1.100
    • 从服务器(Slave):192.168.1.101

2. 主服务器配置

  1. 编辑 MySQL 配置文件
    找到 my.ini 文件,通常位于 C:\ProgramData\MySQL\MySQL Server X.X\(X.X为版本号)。添加或修改以下参数:

    [mysqld]
    server-id = 1
    log-bin = mysql-bin
    binlog-do-db = your_database_name  # 如果只想复制特定数据库
    
    • server-id:主服务器的唯一标识符,必须是一个正整数。
    • log-bin:启用二进制日志,这对于复制是必需的。
    • binlog-do-db:可选,指定要复制的数据库。
  2. 重启 MySQL 服务
    可以通过服务管理器或命令提示符重启 MySQL 服务。

  3. 创建复制用户
    连接到 MySQL 命令行,执行以下命令:

    CREATE USER 'replica'@'%' IDENTIFIED BY 'replica_password';
    GRANT REPLICATION SLAVE ON *.* TO 'replica'@'%';
    FLUSH PRIVILEGES;
    
    • 这个用户将用于从服务器连接到主服务器。
  4. 获取主服务器状态
    在 MySQL 命令行中执行:

    SHOW MASTER STATUS;
    

    记录结果中的 FilePosition 字段,以便在从服务器上使用。

3. 从服务器配置

  1. 编辑从服务器的 MySQL 配置文件
    找到从服务器的 my.ini 文件,添加或修改以下参数:

    [mysqld]
    server-id = 2
    
    • server-id:从服务器的唯一标识符,必须与主服务器不同。
  2. 重启从服务器的 MySQL 服务

  3. 连接到从服务器
    打开 MySQL 命令行,执行以下命令:

    CHANGE MASTER TOMASTER_HOST='192.168.1.100',MASTER_USER='replica',MASTER_PASSWORD='replica_password',MASTER_LOG_FILE='mysql-bin.000001',  -- 使用从主服务器获取的 FileMASTER_LOG_POS=12345;                 -- 使用从主服务器获取的 Position
    
    • 替换 MASTER_LOG_FILEMASTER_LOG_POS 为你在主服务器上记录的值。
  4. 启动复制
    执行以下命令启动复制:

    START SLAVE;
    
  5. 检查复制状态
    输入以下命令检查复制状态:

    SHOW SLAVE STATUS\G
    
    • 确保 Slave_IO_RunningSlave_SQL_Running 都显示为 Yes,这表示复制正在正常运行。

6. 测试复制

  1. 在主服务器上创建一些数据:

    USE your_database_name;
    CREATE TABLE test_table (id INT PRIMARY KEY, name VARCHAR(50));
    INSERT INTO test_table VALUES (1, 'test_name');
    
  2. 在从服务器上查询该表:

    USE your_database_name;
    SELECT * FROM test_table;
    

    你应该能看到在主服务器上插入的数据。

7. 注意事项

  • 防火墙设置:确保主从服务器之间的网络连接正常,防火墙不会阻止 MySQL 的端口(默认是 3306)。
  • 数据一致性:在配置复制之前,确保主从服务器的数据一致性。可以通过备份和恢复的方式来确保这一点。
  • 监控复制状态:定期检查从服务器的复制状态,以确保没有错误发生。

通过以上步骤,你应该能够成功在 Windows 上设置 MySQL 的主从复制。如有问题,请查看 MySQL 错误日志以诊断问题。

http://www.lryc.cn/news/428068.html

相关文章:

  • 鸿蒙内核源码分析(原子操作篇) | 谁在为原子操作保驾护航
  • vue3+ts封装axios以及解决跨域问题
  • 各厂家BI对比
  • SQL - 触发器
  • Redis中缓存穿透、缓存击穿、缓存雪崩的详解
  • [Meachines] [Medium] Popcorn SQLI+Upload File+PAM权限提升
  • 【Linux】python进程管理之supervisor安装使用教程
  • BEM架构
  • 物联网(IoT)详解
  • ansync/await 运行流程图
  • 生产环境docker nginx+php8.0镜像
  • 【Hadoop】核心组件深度剖析:HDFS、YARN与MapReduce的奥秘
  • Docker Swarm部署SpringCloud Alibaba微服务踩坑记录
  • 深入理解Spring Boot中的AOP应用:从基础组件到高级功能的实现
  • 《区块链与监管合规:在创新与规范之间寻求平衡》
  • Nuxt3【服务器】server 详解
  • 防火墙技术原理与应用
  • 【BUU】[NewStarCTF 2023 公开赛道]Final -CP读取文件内容
  • 火绒安全:一款强大且高效的国产杀毒软件
  • Oracle 的DBA有哪些权限
  • 在navicat上运行sql文件
  • STM32裸机和RTOS中的线程安全问题及STM32cubeMX中的线程安全策略
  • 图的遍历
  • CUDA-MODE课程笔记 第8课: CUDA性能检查清单
  • 【备战蓝桥杯青少组】第二天 奇特的砖墙
  • 图像处理 -- 仿射变换之Affine Transformation
  • Nuxt3【项目配置】nuxt.config.ts
  • 中智讯“2024高校人工智能边缘应用项目实战师资培训班”圆满举办
  • IIS发布打包后文件
  • 四个自定义 SHAP 图