MYSQL的主从复制知识点整理

 更新时间:2019年11月10日 14:08:29   作者:ningjiabing  
在本篇文章里小编给大家整理的是一篇关于MYSQL主从复制的相关知识点内容,有需要的朋友们参考学习下。

当单台MYSQL服务器无法满足当前网站流量时的优化方案。需要搭建mysql集群技术。

一、功能:

当向主服务器插入|修改|删除数据时,数据会自动同步到从服务器。

注意:主从复制是单向的,只能主 -> 从

分为两种类型:发射型(一主多从):一般使用在:备份、读写分离。

 

环形(多主多从):一般使用:当主服务器压力大时、跨地区的网站实现数据同步

 

在环形结构中,如果同时向三台服务器的同一表插入记录会出现“ID冲突的问题”。

解决办法:让三台服务器生成不同的ID;

第一台:1,4,7...

第二台:2,5,8..

第三台:3,6,9...

这个可以MYSQL的配置文件中设置:

二、主从的原理(利用了bin日志)

Mysql中有一种日志叫做bin日志(二进制日志)。这个日志会记录下所有修改了数据库的SQL语句(insert,update,delete,ALTER TABLE,grant等等)。主从复制的原理其实就是把主服务器上的BIN日志复制到从服务器上执行一遍,这样从服务器上的数据就和主服务器上的数据相同了。

扩展:mysql中的日志:

查询日志错误日志 Bin日志

慢日志:你可以设置一个时间阀值,如0.5秒,那么将来所以执行时间超过这个值的SQL语句就会被记录下来。这样我们就可以把慢的SQL语句记录下来,专门进行优化。

用途:可以快速定位到网站中比较拖网站的SQL,然后可以优化:建索引,缓存这个SQL的结果。

三、实际的配置

把windows系统的MYSQL做为主服务器,LINUX下的做为从服务器。

主服务器:

1. 开启bin日志

修改mysql的配置文件:my.ini添加:

 

为服务器指定一个server-id(主从服务器的ID值不能重复)

 

如果是环形的服务器需要添加以下项:

log-slave-updates = on // 如果是环形多服务器,要设置这一项,

在主服务器上为从服务器创建一个用来同步数据的账号

登录MYSQL

执行一个SQL:

创建了一个只有REPLICATION SLAVE权限的账号:用户名:slave密码:1234

 

在主服务器执行SQL查看主服务器当前bin日志的状态

 

注意:每次修改数据时这两个值都会改变,所以在查看了这两个值之后,不要操作主服务器、直接到从服务器配置完成之后,否则这个值对应不上会同步失败。

从服务器(linux):

开启bin日志

修改配置文件/etc/my.cnf

 

 

设置一个server-id:

3. 如果是环形的服务器需要添加以下项:

log-slave-updates = on // 如果是环形多服务器,要设置这一项,

4.在从服务器上执行SQL语句配置主服务器的地址:

登录MYSQL:

 

设置从服务器并启动复制功能 

 5.执行SQL查询从服务器的状态是否配置成功:

 

如果是两个YES那么代码成功!完成!

说明:在配置成功之前,主服务器上的数据不会自动到从服务器上来。所以需要在配置之前先把主服务器上的所有数据先手动的导到从服务器上来,然后配置完主从之后,数据以后就同步了。

应用场合:

从服务器做为数据的备份服务器。当服务器压力比较大时可以使用主从服务器实现读、写分离来分流减轻服务器的压力。跨地域网站的优化

制作一个留言板的功能,考虑到不同地域优化的架构思路?

以上就是关于MYSQL主从复制的全部原理知识点,感谢大家的学习和对脚本之家的支持。

相关文章

  • mysql中如何对列求和

    mysql中如何对列求和

    这篇文章主要介绍了mysql中如何对列求和问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • MySQL子查询的实现示例

    MySQL子查询的实现示例

    MySQL中的子查询是一个强大的功能,本文主要介绍了MySQL子查询的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-08-08
  • Mysql启动的方式(四种)

    Mysql启动的方式(四种)

    本文给大家介绍四种mysql启动方式,实用性非常高,感兴趣的朋友参考下吧
    2016-04-04
  • 解决MySQL8.0安装第一次登陆修改密码时出现的问题

    解决MySQL8.0安装第一次登陆修改密码时出现的问题

    这篇文章主要介绍了解决MySQL8.0安装第一次登陆修改密码时出现的问题,在文章开头给大家介绍了mysql 8.0.16 初次登录修改密码的方法,需要的朋友可以参考下
    2019-06-06
  • 手把手带你彻底卸载MySQL数据库

    手把手带你彻底卸载MySQL数据库

    相信大家都因为各种各样的原因可能需要卸载MySQL或者卸载重装,但是如果MySQL不能清理干净的话是很容易出现问题的,这篇文章主要给大家介绍了关于如何彻底卸载MySQL数据库的相关资料,需要的朋友可以参考下
    2022-06-06
  • MYSQL半同步配置思路

    MYSQL半同步配置思路

    在默认设置下,MySQL使用异步复制,主库发送binlog后不等待从库确认,可能导致数据不一致或丢失,半同步复制则在主库更新数据后先等待从库确认同步完成,本文给大家介绍MYSQL半同步配置,感兴趣的朋友一起看看吧
    2023-09-09
  • Windows下mysql5.7.21安装详细教程

    Windows下mysql5.7.21安装详细教程

    这篇文章主要为大家详细介绍了Windows下mysql5.7.21安装详细教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-02-02
  • 关于mysql的时区问题

    关于mysql的时区问题

    这篇文章主要介绍了关于mysql的时区问题,具有很好的参考价值,希望对大家有所帮助,以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家,
    2023-11-11
  • MySQL半同步复制原理配置与介绍详解

    MySQL半同步复制原理配置与介绍详解

    这篇文章主要介绍了MySQL半同步复制原理配置与介绍详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-01-01
  • MySQL删除表的时候忽略外键约束的简单实现

    MySQL删除表的时候忽略外键约束的简单实现

    下面小编就为大家带来一篇MySQL删除表的时候忽略外键约束的简单实现。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03

最新评论