在Linux上配置MariaDB的主从复制涉及几个步骤。以下是一个基本的指南,假设你已经在两台服务器上安装了MariaDB,并且它们可以通过网络相互通信。
/etc/my.cnf
或/etc/mysql/my.cnf
),添加以下内容:[mysqld]
server-id = 1
log_bin = /var/log/mysql/mysql-bin.log
binlog_do_db = mydb # 替换为你想要复制的数据库名称
sudo systemctl restart mariadb
CREATE USER 'replicator'@'%' IDENTIFIED BY 'password'; # 替换为你的密码
GRANT REPLICATION SLAVE ON *.* TO 'replicator'@'%';
FLUSH PRIVILEGES;
SHOW MASTER STATUS;
记下File
和Position
的值。
[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
sudo systemctl restart mariadb
File
和Position
值:CHANGE MASTER TO
MASTER_HOST='master_ip', # 替换为主服务器的IP地址
MASTER_USER='replicator',
MASTER_PASSWORD='password', # 替换为你的密码
MASTER_LOG_FILE='mysql-bin.000001', # 替换为你记录的文件名
MASTER_LOG_POS=123; # 替换为你记录的位置
START SLAVE;
SHOW SLAVE STATUS\G
在SHOW SLAVE STATUS
的输出中,Slave_IO_Running
和Slave_SQL_Running
两个状态都应该是Yes
。如果不是,你需要检查错误信息并解决问题。
mysqldump
或其他数据库同步工具来完成。以上步骤提供了一个基本的MariaDB主从复制配置。根据你的具体需求和环境,可能需要进行额外的配置和调整。