Mysql主从复制和Mysql高可用以及负载均衡配置

需要先配置MySQL主从复制,然后再在主MySQL服务器上配置MySQL Router。以下是详细说明和步骤:

1. 为什么需要先配置MySQL主从复制?

MySQL主从复制是MySQL高可用性和负载均衡的基础,通过将数据从主服务器实时同步到从服务器,确保数据一致性和可用性。在配置MySQL Router之前,需要确保主从复制环境正常工作,这样MySQL Router才能根据主从架构进行读写分离和负载均衡。

2. MySQL主从复制配置步骤

以下是配置MySQL主从复制的主要步骤,参考:

(1)主服务器配置
  1. 开启二进制日志 :修改主服务器的配置文件(如my.cnf),确保以下设置:

    ini 复制代码
    [mysqld]
    server-id = 1
    log-bin = mysql-bin
    binlog-format = ROW
    binlog-do-db = your_database_name
  2. 创建复制用户

    sql 复制代码
    CREATE USER 'repl'@'%' IDENTIFIED BY 'password';
    GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';
    FLUSH PRIVILEGES;
  3. 记录主服务器状态

    sql 复制代码
    SHOW MASTER STATUS;

    记录FilePosition值,用于从服务器配置。

(2)从服务器配置
  1. 修改配置文件 :设置server-idrelay-log

    ini 复制代码
    [mysqld]
    server-id = 2
    relay-log = mysql-relay-bin
  2. 配置主服务器信息

    sql 复制代码
    CHANGE MASTER TO
    MASTER_HOST='master_ip',
    MASTER_USER='repl',
    MASTER_PASSWORD='password',
    MASTER_LOG_FILE='mysql-bin.000001',  -- 主服务器记录的File值
    MASTER_LOG_POS=701;  -- 主服务器记录的Position值
  3. 启动复制

    sql 复制代码
    START SLAVE;
    SHOW SLAVE STATUS \G;

    检查Slave_IO_RunningSlave_SQL_Running状态是否为Yes

(3)验证主从同步

在主服务器执行写操作,然后查看从服务器是否同步:

sql 复制代码
SHOW SLAVE STATUS \G;

3. MySQL Router配置步骤

MySQL Router是一个轻量级中间件,用于实现读写分离、负载均衡和故障转移。以下是配置步骤,参考:

(1)安装MySQL Router

根据操作系统选择安装方式,例如在Ubuntu上:

bash 复制代码
sudo apt-get install mysql-router
(2)配置MySQL Router
  1. 生成配置文件

    bash 复制代码
    mysqlrouter --bootstrap root@localhost:3306 <<EOF
    mysqlrouter --user=mysqlrouter
    EOF
  2. 编辑配置文件mysqlrouter.conf):

    • 添加主服务器和从服务器信息:

      ini 复制代码
      [routing:writer]
      bind_address = 127.0.0.1
      port = 6446
      destinations = writer1:3306
      [routing:reader]
      bind_address = 127.0.0.1
      port = 6447
      destinations = reader1:3306,reader2:3306
    • 配置读写分离策略:

      ini 复制代码
      [default]
      routing_strategy = round-robin
(3)启动MySQL Router
bash 复制代码
mysqlrouter &
(4)测试连接
  1. 连接到主服务器

    bash 复制代码
    mysql -h 127.0.0.1 -P 6446 -u your_username -p
  2. 连接到从服务器

    bash 复制代码
    mysql -h 127.0.0.1 -P 6447 -u your_username -p

4. 配置顺序总结

  1. 先配置MySQL主从复制:确保主从服务器之间的数据同步正常。
  2. 再配置MySQL Router:在主服务器上安装并配置MySQL Router,实现读写分离和负载均衡。
相关推荐
Joseph Cooper3 分钟前
Linux/Android 跟踪技术:ftrace、TRACE_EVENT、atrace、systrace 与 perfetto 入门
android·linux·运维
空中海29 分钟前
安卓逆向03. 动态调试、抓包分析与 Frida Hook
android
一起搞IT吧2 小时前
相机Camera日志实例分析之二十:相机Camx【照片后置4800/5000/6400万拍照】单帧流程日志详解
android·嵌入式硬件·数码相机·智能手机
jinanwuhuaguo3 小时前
(第三十三篇)五月的文明奠基:OpenClaw 2026.5.2版本的文明级解读
android·java·开发语言·人工智能·github·拓扑学·openclaw
DevilSeagull4 小时前
MySQL(2) 客户端工具和建库
开发语言·数据库·后端·mysql·服务
千码君20164 小时前
Trae:一些关于flutter和 go前后端开发构建的分享
android·flutter·gradle·android-studio·trae·vibe code
远洪5 小时前
claude code 国内安装使用
数据库·mysql
遇见火星7 小时前
Nginx 负载均衡配置模板:轮询、权重、IP哈希、最少连接
tcp/ip·nginx·负载均衡
wangbing11257 小时前
MySQL 官方 GPG 密钥过期问题
数据库·mysql
重生之我是Java开发战士8 小时前
【MySQL】事务 & 用户与权限管理
android·数据库·mysql