mysql双主架构操作步骤

准备 centos8 mysql 8

master1:10.0.0.10
master2:10.0.0.12

master1 mysql配置

# vim /etc/my.cnf

log-bin=mysql-bin   #日志名称

log=/home/mysqld.log

server-id=200

binlog-do-db=test  #同步的数据库

auto-increment-increment=2

auto-increment-offset=2

master2 mysql配置

# vim /etc/my.cnf

log-bin=mysql-bin   #日志名称

log=/home/mysqld.log

server-id=201

binlog-do-db=test  #同步的数据库

auto-increment-increment=2

auto-increment-offset=2

配置好了,要重启数据库(两个)

systemctl restart mysqld;

master1,master2授权用户(都执行一遍)

create user 'jacob'@'%' identified by 'Qwe!1234';

再赋予权限

grant replication slave on *.* to 'jacob'@'%' with grant option;

#在之后show slave status\G;时可能报错:Authentication plugin #‘caching_sha2_password‘ reported error: Authentication,所以加上下面的操作

alter user 'jacob'@'%' identified with mysql_native_password by 'Qwe!1234';

flush privileges;

查看master1状态:

show master status;

查看master2状态

show master status;

master1执行

change master to master_host= '10.0.0.12', master_user='jacob', master_password='Qwest!1234', master_log_file='mysqlbin.000003', master_log_pos=751;

在master2

change master to master_host= '10.0.0.10', master_user='jacob', master_password='Qwest!1234', master_log_file='mysqlbin.000005', master_log_pos=449;

 两台服务器都开启同步操作:

start slave; #开启同步
show slave status; #查看状态

 基本上这样就是好了

Fatal error:The slave I/O thread stops because master and slave have equal MySQL server UUIDs;

解决方法就是找到主机和从机的auto.cnf文件修改uuid值或删除auto.cnf这个文件。

执行find / -name auto.cnf命令查看auto.cnf文件的位置,在./mysql/data/auto.cnf位置。

然后随便修改一个文件里的值,然后执行service mysqld restart命令重启主机和从机的mysql服务

如果其中一台服务器重启可能会报1062错误

在重启的服务器上执行下面的操作可解决

mysql> stop slave;
mysql> set global sql_slave_skip_counter=1;

mysql> start slave;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL双主+Keepalived是一种高可用性架构,它允许在两个MySQL主服务器之间实现数据同步和故障切换。Keepalived是一个开源的高可用性解决方案,可用于监视和管理服务器的状态,并在主服务器出现故障时自动将流量切换到备用主服务器。 在MySQL双主架构中,两个主服务器都可以接收写入操作,并且彼此之间进行数据同步以保持数据一致性。当其中一个主服务器发生故障或需要维护时,Keepalived会检测到该状态变化,并将流量切换到备用主服务器,确保应用程序的持续可用性。 实现MySQL双主+Keepalived需要进行以下步骤: 1. 配置两个MySQL主服务器,确保它们能够相互通信并进行数据同步。可以使用MySQL的复制功能来实现数据的实时同步。 2. 安装和配置Keepalived,在两个主服务器上分别安装Keepalived软件包,并进行必要的配置。配置文件包括虚拟IP地址、监控检查脚本和故障切换设置等。 3. 启动Keepalived,保证两个主服务器上的Keepalived服务都在运行状态。 4. 进行故障测试,模拟其中一个主服务器宕机或网络故障的情况,观察Keepalived是否能够及时检测到故障并切换流量到备用主服务器。 5. 定期进行维护和监控,确保MySQL主服务器和Keepalived服务的稳定性。 需要注意的是,MySQL双主+Keepalived架构需要合理配置和管理,以确保数据一致性和高可用性。在进行故障切换时,可能会有一定的数据丢失或延迟,因此需要根据业务需求和数据重要性来评估和调整配置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值