当前位置: 移动技术网 > IT编程>数据库>Mysql > MYSQL的主从复制知识点整理

MYSQL的主从复制知识点整理

2020年03月09日  | 移动技术网IT编程  | 我要评论
当单台mysql服务器无法满足当前网站流量时的优化方案。需要搭建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主从复制的全部原理知识点,感谢大家的学习和对移动技术网的支持。

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

  • Ubuntu上Vim安装NERDTree插件的详细操作步骤

    Ubuntu上Vim安装NERDTree插件的详细操作步骤

    nerdtree是vim的文件系统浏览器,使用此插件,用户可以直观地浏览复杂的目录层次结构,快速打开文件以进行读取或编辑,以及执行基本的文件系统操作。nerdt... [阅读全文]
  • MySQL 4种常用的主从复制架构

    MySQL 4种常用的主从复制架构

    一主多从复制架构在主库读取请求压力非常大的场景下,可以通过配置一主多从复制架构实现读写分离,把大量的对实时性要求不是特别高的读请求通过负载均衡分部到多个从库上(... [阅读全文]
  • 浅析MySQL 备份与恢复

    1、简介数据无价,mysql作为一个数据库系统,其备份自然也是非常重要且有必要去做。备份的理由千千万,预防故障,安全需求,回滚,审计,删了又改的需求等等,备份的... [阅读全文]
  • 保障MySQL数据安全的一些建议

    数据是企业核心资产,数据对企业而言是最重要的工作之一。稍有不慎,极有可能发生数据无意泄露,甚至被黑客恶意窃取的风险。每年业界都会传出几起大事件,某知名或不知名的... [阅读全文]
  • MySQL如何快速修改表的表结构

    快速修改mysql某张表的表结构--摘录自《mysql管理之道》alter table 表名 modify 列名 数据类型; 这个命令可以修改表结构此外,也可以... [阅读全文]
  • MySQL 行锁和表锁的含义及区别详解

    一、前言对于行锁和表锁的含义区别,在面试中应该是高频出现的,我们应该对mysql中的锁有一个系统的认识,更详细的需要自行查阅资料,本篇为概括性的总结回答。mys... [阅读全文]
  • MySQL 如何查询当前最新事务ID

    写在前面:在个别时候可能需要查看当前最新的事务 id,以便做一些业务逻辑上的判断(例如利用事务 id 变化以及前后时差,统计每次事务的响应时长等用途)。通常地,... [阅读全文]
  • 如何优雅、安全的关闭MySQL进程

    前言本文分析了 mysqld 进程关闭的过程,以及如何安全、缓和地关闭 mysql 实例,对这个过程不甚清楚的同学可以参考下。关闭过程1、发起 shutdown... [阅读全文]
  • 详解MySQL8.0​ 字典表增强

    详解MySQL8.0​ 字典表增强

    mysql中数据字典是数据库重要的组成部分之一,information_schema首次引入于mysql 5.0,作为一种从正在运行的mysql服务器检索元数据... [阅读全文]
  • 简述MySQL InnoDB存储引擎

    前言:存储引擎是数据库的核心,对于 mysql 来说,存储引擎是以插件的形式运行的。虽然 mysql 支持种类繁多的存储引擎,但最常用的当属 innodb 了,... [阅读全文]
验证码:
移动技术网