linux

Linux MariaDB主从复制配置方法

小樊
42
2025-09-02 16:15:08
栏目: 云计算

在Linux上配置MariaDB的主从复制涉及几个步骤。以下是一个基本的指南,假设你已经在两台服务器上安装了MariaDB,并且它们可以通过网络相互通信。

步骤 1: 配置主服务器

  1. 编辑主服务器的MariaDB配置文件(通常是/etc/my.cnf/etc/mysql/my.cnf),添加以下内容:
[mysqld]
server-id = 1
log_bin = /var/log/mysql/mysql-bin.log
binlog_do_db = mydb # 替换为你想要复制的数据库名称
  1. 重启MariaDB服务以应用更改:
sudo systemctl restart mariadb
  1. 登录到MariaDB,并为从服务器创建一个具有复制权限的用户:
CREATE USER 'replicator'@'%' IDENTIFIED BY 'password'; # 替换为你的密码
GRANT REPLICATION SLAVE ON *.* TO 'replicator'@'%';
FLUSH PRIVILEGES;
  1. 查看主服务器的二进制日志位置和文件名,这将用于从服务器的配置:
SHOW MASTER STATUS;

记下FilePosition的值。

步骤 2: 配置从服务器

  1. 编辑从服务器的MariaDB配置文件,添加以下内容:
[mysqld]
server-id = 2
relay_log = /var/log/mysql/mysql-relay-bin.log
log_bin = /var/log/mysql/mysql-bin.log
binlog_do_db = mydb # 替换为你想要复制的数据库名称
read_only = 1
  1. 重启MariaDB服务以应用更改:
sudo systemctl restart mariadb
  1. 登录到MariaDB,并配置复制,使用之前在主服务器上获取的FilePosition值:
CHANGE MASTER TO
MASTER_HOST='master_ip', # 替换为主服务器的IP地址
MASTER_USER='replicator',
MASTER_PASSWORD='password', # 替换为你的密码
MASTER_LOG_FILE='mysql-bin.000001', # 替换为你记录的文件名
MASTER_LOG_POS=123; # 替换为你记录的位置
  1. 启动从服务器上的复制进程:
START SLAVE;
  1. 检查从服务器的复制状态:
SHOW SLAVE STATUS\G

SHOW SLAVE STATUS的输出中,Slave_IO_RunningSlave_SQL_Running两个状态都应该是Yes。如果不是,你需要检查错误信息并解决问题。

注意事项

以上步骤提供了一个基本的MariaDB主从复制配置。根据你的具体需求和环境,可能需要进行额外的配置和调整。

0
看了该问题的人还看了