MySQL实现双主双从的架构可以通过MySQL Replication和MHA(Master High Availability)实现。以下是一个简化的方案:
- 两台MySQL服务器配置为主主复制,实现数据同步和自动故障转移。
- 每台MySQL服务器都有一个从服务器备份。
以下是配置步骤:
步骤1: 在两台MySQL服务器上配置主主复制。
# 在服务器A上
server-id=1
log-bin=mysql-bin
auto_increment_increment=2
auto_increment_offset=1
# 在服务器B上
server-id=2
log-bin=mysql-bin
auto_increment_increment=2
auto_increment_offset=2
然后启动复制:
CHANGE MASTER TO MASTER_HOST='服务器B的IP', MASTER_USER='replication_user', MASTER_PASSWORD='replication_password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=1;
CHANGE MASTER TO MASTER_HOST='服务器A的IP', MASTER_USER='replication_user', MASTER_PASSWORD='replication_password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=1;
启动复制:
START SLAVE;
步骤2: 为每台MySQL服务器配置一个从服务器。
# 在服务器A上
server-id=3
CHANGE MASTER TO MASTER_HOST='服务器B的IP', MASTER_USER='replication_user', MASTER_PASSWORD='replication_password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=1;
START SLAVE;
# 在服务器B上
server-id=4
CHANGE MASTER TO MASTER_HOST='服务器A的IP', MASTER_USER='replication_user', MASTER_PASSWORD='replication_password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=1;
START SLAVE;
步骤3: 使用MHA实现自动故障转移。
MHA会监控主服务器,一旦主服务器宕机,它会选举一个从服务器作为新的主服务器,并重新配置复制。
安装MHA:
# 安装MHA node(在所有服务器上)
yum install mha4mysql-node
# 安装MHA manager
yum install mha4mysql-manager
配置MHA:
# /etc/masterha_default.cnf
[server default]
user=mha
password=mha_password
ssh_user=mha
[server1]
hostname=服务器A的IP
candidate_master=1
[server2]
hostname=服务器B的IP
candidate_master=1
[binlog1]
binlog_dir=/var/lib/mysql
启动MHA:
masterha_manager --conf=/etc/masterha_default.cnf
以上步骤提供了一个基本的双主双从架构和自动故障转移的方案。注意,在生产环境中,你需要额外的监控和管理工具来保证整个系统的稳定性和安全性。