linux 实现两台 MySQL 服务器的主从复制
创始人
2025-01-19 16:03:41
0

准备工作:准备好两台服务器,并且已经安装好mysql,两台服务器之间互通

MySQL主从复制介绍

在 MySQL 集群环境中,可以分为主节点与从节点,通过主从复制可以实现数据备份、故障转移(其中一台宕机了可以访问另一台)、MySQL集群、高可用、读写分离等。

MySQL的主从复制原理:主从复制是 MySQL本身自带的一个功能,不需要额外的第三方软件就可以实现,其复制功能并不是copy文件来实现的,而是借助 binlog 日志文件里面的SQL命令实现的主从复制,可以理解为在 Master(主数据库) 端执行了一条SQL命令,那么在 Salve (从数据库)端同样会执行一遍,从而达到主从复制的效果。从库生成两个线程,一个I/O线程,一个SQL线程;  I/O线程去请求主库的 binlog,并将得到的 binlog 日志写到 relay log(中继日志) 文件中; 主库会生成一个 log dump 线程,用来给从库I/O线程传 binlog; 从数据库的 SQL 线程,会读取 relay log文件中的日志,并解析成具体操作,来实现主从的操作一致,而最终数据一致。

主库操作:

           打开作为master(主机)的MySQL配置文件:vi /etc/my.cnf 修改、添加如下配置,前两项为必填项。默认配置的 server-id=1 ,我们修改成200,同时开启日志文件。还有个重要的说明是要同步的数据库名。这里需要根据实际情修改,不填写的话同步的是整个库。

log-bin = mysql-bin

server-id = 200

binlog-do-db = jz_ubp

server-id :主服务器唯一ID
log-bin:启用二进制日志
binlog-ignore-db:设置不要复制的数据库
binlog-do-db:设置需要复制的数据库
binlog-format:设置logbin格式

配置完需要重启数据库(我使用的是docker部署的,可以根据个人的部署方式进行操作)

docker restart mysql

查看,结果为200

show variables like '%server_id%';

查询结果能看到 binlog 文件,即为正确,binlog 的版本是一直在叠加的。3338956是它的行数。

show master status;

建立主从账号

 GRANT REPLICATION SLAVE ON *.* TO admin@'%' identified by 'admin123';    flush privileges; # 刷新权限

从库操作:

打开作为slave(从机)的MySQL配置文件vi /etc/my.cnf 修改、添加如下配置,前两项为必填项

默认配置的 server-id=1 ,修改服务ID为201,以及日志文件同步方式等。

# 从服务器的服务器ID  server_id=201  # 日志文件同步方式  log-bin=mysql-bin  修改后重启数据库  docker restart mysql

验证从服务器

show variables like '%server_id%';

 查看

show master status;

然后,我们需要将【从服务器】同步【主服务器】的配置:在【从服务器】的查询上执行下面的句子(这里的 master_log_file pos 需要根据你的实际情况配置   主库show master status查询的结果):

change master to master_host='192.168.10.104',

master_port=3306,

master_user='admin' ,

master_password='admin123',

Master_log_file=' mysql-bin.000038',

Master_log_pos= 3338956;

然后开始同步

start slave;

-- 检查从服务器复制功能状态,必须2个都是yes才行

show slave status\G;

   至此已经实现了主从同步,但前提是主库在此时新建的库、表会同步到从库。如果主库运行一段时间了,才做的从库,在做主从同步之前,是需要自己手动把主库的数据迁移到从库里的,在两个库基本数据一致情况下,再启动主从同步才能正常使用

相关内容

热门资讯

一分钟了解!创思维辅助器(辅助... 一分钟了解!创思维辅助器(辅助挂)本来有开挂辅助神器(有挂秘籍)1、不需要AI权限,帮助你快速的进行...
安装程序教程!微信小程序微乐破... 安装程序教程!微信小程序微乐破解器,雀友会广东潮汕辅助有开挂,辅助教程(确实有挂)是一款可以让一直输...
指导大家!葫芦娃七子降妖破解版... 指导大家!葫芦娃七子降妖破解版(辅助挂)切实有开挂辅助黑科技(确实有挂);1.葫芦娃七子降妖破解版 ...
一分钟了解!樱花之盛辅助器下载... 您好,樱花之盛辅助器下载这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家...
重大消息!闲逸免费app辅助(... 重大消息!闲逸免费app辅助(辅助挂)其实有开挂辅助平台(的确有挂)1、这是跨平台的闲逸免费app辅...
教程辅助!微乐小程序黑科技免费... 教程辅助!微乐小程序黑科技免费知乎,广东雀神麻木智能插件安装,必赢教程(新版有挂);人气非常高,ai...
玩家爆料!广西老友玩有破解吗(... 玩家爆料!广西老友玩有破解吗(辅助挂)总是有开挂辅助软件(有挂方法);1.广西老友玩有破解吗 ai辅...
科技通报!新荣耀平台辅助,新西... 您好,新西游大厅拼十辅助这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家...
大家学习交流!微信大厅辅助软件... 大家学习交流!微信大厅辅助软件(辅助挂)竟然有开挂辅助脚本(存在有挂)1、完成微信大厅辅助软件透视辅...
解密关于!花花生活圈辅助工具安... 解密关于!花花生活圈辅助工具安装教程(辅助挂)一向有开挂辅助挂(有挂方法);花花生活圈辅助工具安装教...