登录
首页 >  文章 >  linux

Linux下MariaDB主从复制配置超全步骤详解

时间:2025-06-20 16:36:20 370浏览 收藏

本文详细介绍了在Linux环境下配置MariaDB主从复制的步骤,旨在帮助读者搭建稳定可靠的数据同步架构。首先,需要在主服务器上修改配置文件,启用二进制日志,并创建具有复制权限的专用账户。接着,锁定数据库表并记录二进制日志的文件名和位置。然后在从服务器上配置连接主服务器的参数,包括主服务器IP地址、复制账户和密码,以及之前记录的日志文件名和位置。最后,启动从服务器的复制线程,并通过`SHOW SLAVE STATUS`命令检查复制状态,确保主从服务器之间的数据同步正常运行。本文还提供了相关建议,如保持时间一致性、确保server-id唯一等,帮助读者避免常见问题,顺利完成MariaDB主从复制的搭建。

Linux MariaDB如何配置主从复制

在Linux系统中设置MariaDB的主从复制需要完成一系列操作流程。下面将分步骤介绍如何搭建主服务器与从服务器之间的数据同步机制。

主服务器设置

  1. 修改主服务器的配置文件(通常位于/etc/my.cnf或/etc/mysql/my.cnf):

     [mysqld]
     server-id = 1
     log_bin = /var/log/mysql/mysql-bin.log
     binlog_do_db = mydb  # 填入你需要同步的数据库名称
  2. 重启MariaDB服务,使配置生效:

     sudo systemctl restart mariadb
  3. 进入MariaDB控制台并创建一个专用的复制账户

     CREATE USER 'replicator'@'%' IDENTIFIED BY 'password';  # 设置安全密码
     GRANT REPLICATION SLAVE ON *.* TO 'replicator'@'%';
     FLUSH PRIVILEGES;
  4. 锁定数据库表并查看当前二进制日志信息

     FLUSH TABLES WITH READ LOCK;
     SHOW MASTER STATUS;

    注意记录输出中的File和Position字段值。

  5. 释放表锁

     UNLOCK TABLES;

从服务器设置

  1. 编辑从服务器的配置文件(路径同上):

     [mysqld]
     server-id = 2
     relay_log = /var/log/mysql/mysql-relay-bin.log
     log_bin = /var/log/mysql/mysql-bin.log
     read_only = 1
  2. 重启MariaDB服务以启用新的配置参数:

     sudo systemctl restart mariadb
  3. 连接到MariaDB,并执行以下命令来设置复制参数

     CHANGE MASTER TO
     MASTER_HOST='master_ip',  # 输入主服务器IP地址
     MASTER_USER='replicator',
     MASTER_PASSWORD='password',  # 使用你设定的密码
     MASTER_LOG_FILE='mysql-bin.000001',  # 使用之前记录的File值
     MASTER_LOG_POS=123;  # 使用之前记录的Position值
  4. 启动从服务器的复制线程

     START SLAVE;
  5. 查询复制状态是否正常运行

     SHOW SLAVE STATUS\G

    确认Slave_IO_Running和Slave_SQL_Running的状态均为Yes。如果出现异常,请根据提示排查问题。

相关建议

  • 保持主从服务器之间的时间一致性。
  • 每个服务器的server-id必须唯一,不能重复。
  • 若部署多个从节点,应确保每个节点拥有独立的server-id。
  • 推荐在正式环境中采用GTID等更高级别的复制策略以增强可靠性。

按照上述流程操作后,你应该可以顺利完成MariaDB的主从架构搭建。如遇故障,请参考相关日志进行调试分析。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>