mysql5.5和mysql5.6能进行主从同步吗

mysql5.5和mysql5.6能进行主从同步吗,第1张

Mysql5.5和Mysql5.6主从同步设置

主服务器(MySQL5.5)

从服务器(MySQL5.6)

1、在主库创建从库用户

insert into mysql.user(Host,User,Password) values('localhost','slaveuser',password('123456'))

flush privileges

grant replication slave on *.* to 'slaveuser' ' identified by '123456' with grant option

2、修改主库配置文件my.cnf

#编辑配置文件,在[mysqld]部分添加下面内容

vi /etc/my.cnf

#设置服务器id

server-id=80

#启动MySQ二进制日志系统

log_bin=mysql-bin

#需要同步的数据名,如果有多个数据库,可重复此参数,每个数据库一行

binlog-do-db=api

#不同步mysql系统数据库

binlog-ignore-db=mysql

#重启MySQL

service mysqld restart

#进入mysql控制台

mysql -u root -p

#查看主库同步状态

show master status\G

3、修改从库配置文件my.cnf(保证主从server-id不一样,一般用ip最后的字段)

vi /etc/my.cnf

#设置服务器id

server-id=90

3、从库增加配置

#进入mysql控制台

mysql -u root -p

#停止slave同步进程

stop slave

#执行同步语句

change master to master_host=' ',master_user='slaveuser',master_password='123456',master_log_file='mysql-bin.000001' ,master_log_pos=

#开启slave同步进程

start slave

#查看从库同步状态

show slave status\G

MySQL 主从一直是面试常客,里面的知识点虽然基础,但是能回答全的同学不多。

比如楼哥之前面试小米,就被问到过主从复制的原理,以及主从延迟的解决方案,因为回答的非常不错,给面试官留下非常好的印象。你之前面试,有遇到过哪些 MySQL 主从的问题呢?

所谓 MySQL 主从,就是建立两个完全一样的数据库,一个是主库,一个是从库, 主库对外提供读写的 *** 作,从库对外提供读的 *** 作 ,下面是一主一从模式:

对于数据库单机部署,在 4 核 8G 的机器上运行 MySQL 5.7 时,大概可以支撑 500 的 TPS 和 10000 的 QPS, 当遇到一些活动时,查询流量骤然,就需要进行主从分离。

大部分系统的访问模型是读多写少,读写请求量的差距可能达到几个数量级,所以我们可以通过一主多从的方式, 主库只负责写入和部分核心逻辑的查询,多个从库只负责查询,提升查询性能,降低主库压力。

MySQL 主从还能做到服务高可用,当主库宕机时,从库可以切成主库,保证服务的高可用,然后主库也可以做数据的容灾备份。

整体场景总结如下:

MySQL 的主从复制是依赖于 binlog 的,也就是记录 MySQL 上的所有变化并以二进制形式保存在磁盘上二进制日志文件。

主从复制就是将 binlog 中的数据从主库传输到从库上,一般这个过程是异步的,即主库上的 *** 作不会等待 binlog 同步的完成。

详细流程如下:

当主库和从库数据同步时,突然中断怎么办?因为主库与从库之间维持了一个长链接,主库内部有一个线程,专门服务于从库的这个长链接的。

对于下面的情况,假如主库执行如下 SQL,其中 a 和 create_time 都是索引:

我们知道,数据选择了 a 索引和选择 create_time 索引,最后 limit 1 出来的数据一般是不一样的。

所以就会存在这种情况:在 binlog = statement 格式时,主库在执行这条 SQL 时,使用的是索引 a,而从库在执行这条 SQL 时,使用了索引 create_time,最后主从数据不一致了。

那么我们改如何解决呢?

可以把 binlog 格式修改为 row,row 格式的 binlog 日志记录的不是 SQL 原文,而是两个 event:Table_map 和 Delete_rows。

Table_map event 说明要 *** 作的表,Delete_rows event用于定义要删除的行为,记录删除的具体行数。 row 格式的 binlog 记录的就是要删除的主键 ID 信息,因此不会出现主从不一致的问题。

但是如果 SQL 删除 10 万行数据,使用 row 格式就会很占空间的,10 万条数据都在 binlog 里面,写 binlog 的时候也很耗 IO。但是 statement 格式的 binlog 可能会导致数据不一致。

设计 MySQL 的大叔想了一个折中的方案,mixed 格式的 binlog,其实就是 row 和 statement 格式混合使用, 当 MySQL 判断可能数据不一致时,就用 row 格式,否则使用就用 statement 格式。

有时候我们遇到从数据库中获取不到信息的诡异问题时,会纠结于代码中是否有一些逻辑会把之前写入的内容删除,但是你又会发现,过了一段时间再去查询时又可以读到数据了,这基本上就是主从延迟在作怪。

主从延迟,其实就是“从库回放” 完成的时间,与 “主库写 binlog” 完成时间的差值, 会导致从库查询的数据,和主库的不一致

谈到 MySQL 数据库主从同步延迟原理,得从 MySQL 的主从复制原理说起:

总结一下主从延迟的主要原因 :主从延迟主要是出现在 “relay log 回放” 这一步,当主库的 TPS 并发较高,产生的 DDL 数量超过从库一个 SQL 线程所能承受的范围,那么延时就产生了,当然还有就是可能与从库的大型 query 语句产生了锁等待。

我们一般会把从库落后的时间作为一个重点的数据库指标做监控和报警,正常的时间是在毫秒级别,一旦落后的时间达到了秒级别就需要告警了。

解决该问题的方法,除了缩短主从延迟的时间,还有一些其它的方法,基本原理都是尽量不查询从库。

具体解决方案如下:

在实际应用场景中,对于一些非常核心的场景,比如库存,支付订单等,需要直接查询从库,其它非核心场景,就不要去查主库了。

两台机器 A 和 B,A 为主库,负责读写,B 为从库,负责读数据。

如果 A 库发生故障,B 库成为主库负责读写,修复故障后,A 成为从库,主库 B 同步数据到从库 A。

一台主库多台从库,A 为主库,负责读写,B、C、D为从库,负责读数据。

如果 A 库发生故障,B 库成为主库负责读写,C、D负责读,修复故障后,A 也成为从库,主库 B 同步数据到从库 A。

MySQL主从关系设置

一,概要

1.这个文档主要实现的是MYSQL主从备份(主机数据库任何修改,备份机器都会有实现)

2.但是有个问题,就是如果对备份机器数据库进行 *** 作,可能会导致连接失败。

二,准备工作

1.可以是多台主机和从机,在这里我只用一台主机和从机为例讲解主从关系配置。2.主机IP:192.168.0.100(例子)从机IP:192.168.0.101(例子)3.主机和从机的IP地址必须是一个网段的。

4.MySQL版本:mysql-5.5.15-win32.msi安装路径:D:\MySQL\(例子)5.其他相关软件:

①.MySQL管理客户端:Navicat8forMySQL(Windows)。

②.编辑工具:Notepad++(建议用此编辑工具修改MySQL配置文件,点击此链接进入下载

页面)

三,配置主机【master】(IP:192.168.0.100)

1.在命令行窗口中执行:netstopmysql关闭mysql服务。

2.在mysql安装路径下找到配置文件my.ini文件(Linux下是文件my.cnf),一般都在MySQL安装目录下,本实验中在D:\MySQL\下。记得先备份以下原来的配置文件。并用Notepad++打开。然后在文件末尾加入下面的代码:

server-id=1#配一个唯一的ID编号

log-bin=NEW_NAME#指定日志类型

binlog-do-db=bojinv2#设置要进行主从复制的数据库名,同时也要在从机

【Slave】上设定(同步多个另起一行输入这行代码)

Binlog-ignore-db=mysql#设置不要进行主从复制的数据库名,同时也要在

【Slave】上设定(不同步多个另起一行输入这行代码

即可。)

3.在系统管理命令窗口输入:netstartmysql按回车启动mysql服务

4.在MySQL5.5CommandLineClient命令窗口(路径:开始菜单》程序》MySQL下),

输入数据库密码:******回车,如下图所示:

然后输入:grantreplicationslaveon*.*toslaveuser@从机IP(例:192.168.1.101)identifiedby'从机数据库密码(例:123456)'回车后如下图所示:

var cpro_psid ="u2572954"var cpro_pswidth =966var cpro_psheight =120

出现这样的提示后,继续输入:flushprivileges按回车,如下图所示:

出现这样的提示后,继续输入:showmasterstatus按回车,如下图所示:

记住出现的表格中的File列和Position的值。

5.在系统管理命令窗口输入:netstopmysql按回车关闭mysql服务

6.进入MySQL管理客户端:Navicat8forMySQL(Windows)。点击菜单栏用户,右侧显示你

刚才创建slaveuser@192.168.1.101的用户,选中该用户。点击编辑用户链接。d出窗口,再

选择权限,将所有权限都选上保存,这样主机就配置好了。重启一下MySQL服务。

四,配置从机【slave】(Ip:192.168.1.101)

1.在命令行窗口中执行:netstopmysql关闭mysql服务。

2.在mysql安装路径下找到配置文件my.ini文件(Linux下是文件my.cnf),一般都

在MySQL安装目录下,本实验中在D:\MySQL\下。记得先备份以下

原来的配置文件。并用Notepad++打开。然后在文件末尾加入下面的代

码:

server-id=2#配一个唯一的ID编号,不能与主机和其他的从机相同

replicate-do-db=bojinv2#设置要进行主从复制的数据库名,数据库名与主机

相同

replicate-ignore-db=mysql#设置不要进行主从复制的数据库名,数据库名与

主机相同

别忘了保存修改后的文件。

3.在系统管理命令窗口输入:netstartmysql按回车启动mysql服务

4.在MySQL5.5CommandLineClient命令窗口(路径:开始菜单》程序》MySQL下),

输入数据库密码,按回车成功登录数据库。5.登录成功后,在该命令窗口输入:

Changemastertomaster_host='主机IP(192.168.1.100)',master_user='


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6140950.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-16
下一篇 2023-03-16

发表评论

登录后才能评论

评论列表(0条)

保存