• 【Java实战】Mysql读写分离主从复制搭建保姆级教程


    MySQL 的数据同步通常采用主从复制(Master-Slave)的方式。 主从复制基于二进制日志(binlog)。主服务器(Master)在 binlog 中记录数据更改,从服务器(Slave)将这些日志读取并应用到自己的数据库,以此实现数据的同步。从服务器有两个线程:IO线程从主服务器读取 binlog 并保存在本地的中继日志(relay log);SQL线程读取中继日志,执行其中的事件,确保从服务器数据与主服务器保持一致

    以下是配置 MySQL 主从复制的步骤:

    一 配置主服务器(Master)

    1.0 编辑 MySQL 配置文件 /etc/my.cnf

    1. [mysqld]
    2. server-id=1
    3. log-bin=mysql-bin
    4. binlog-do-db=你创建的dbname

    1.1 重启 MySQL 服务

    systemctl restart mysqld

    1.2 登录 MySQL,并创建用于复制的用户。

    1. mysql -uroot -p 
    2. CREATE USER 'repl_user'@'%' IDENTIFIED BY '你的密码';
    3. GRANT REPLICATION SLAVE ON *.* TO 'repl_user'@'%';

    1.3 查看主服务器状态,记录文件名和位置。

    SHOW MASTER STATUS;

    二 配置从服务器(Slave)

    2.0 编辑 MySQL 配置文件 my.cnf(Slave)

    1. [mysqld]
    2. server-id=2

    2.1 重启从服务器(Slave)

    systemctl restart mysqld

    2.2 登录 MySQL

    mysql -uroot -p

    2.3 并配置从服务器连接到主服务器(slave)

    1. CHANGE MASTER TO
    2.   MASTER_HOST='你的master的IP',
    3.   MASTER_USER='repl_user',
    4.   MASTER_PASSWORD='你的master上repl_user用户的密码',
    5.   MASTER_LOG_FILE='你的master_log_file',
    6.   MASTER_LOG_POS=你的master_log_position;

    如何获取 MASTER_LOG_FILE 和 MASTER_LOG_POS

    在主服务器(Master)上登录, MySQL 执行以下 SQL 命令:

    SHOW MASTER STATUS;

    这里,File 列是 MASTER_LOG_FILE 的值(如:mysql-bin.000002),Position 列是 MASTER_LOG_POS 的值

    2.4 启动 Slave

    START SLAVE;

    查看从服务器状态,确认复制是否正在运行。

    SHOW SLAVE STATUS\G;

    三 验证Mysql主从服务器

    在Master上,创建表、添加几个字段、数据增加、修改、删除。

    观察Slave上面数据是否一致。

  • 相关阅读:
    sentinel-1.8.7与nacos-2.3.0实现动态规则配置、双向同步
    实验四.集合
    多线程&并发篇---第四篇
    数据分析---主要工作
    Linux软链接妙用(硬链接妙用)
    基于Vite初始化前端项目
    Python绘图布局设计
    创龙瑞芯微RK3568参数修改(调试口波特率和rootfs文件)
    Spring Security 单点登出
    Windows OpenGL 图像反色
  • 原文地址:https://blog.csdn.net/forgetmiss/article/details/133881224