MYSQL的主从复制知识点整理

作者:ningjiabing 时间:2024-01-26 02:54:29 

当单台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添加:

 MYSQL的主从复制知识点整理

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

 MYSQL的主从复制知识点整理

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

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

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

登录MYSQL

执行一个SQL:

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

 MYSQL的主从复制知识点整理

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

 MYSQL的主从复制知识点整理

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

从服务器(linux):

开启bin日志

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

 MYSQL的主从复制知识点整理

 MYSQL的主从复制知识点整理

设置一个server-id:

MYSQL的主从复制知识点整理

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

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

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

登录MYSQL:

 MYSQL的主从复制知识点整理

设置从服务器并启动复制功能 MYSQL的主从复制知识点整理

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

 MYSQL的主从复制知识点整理

MYSQL的主从复制知识点整理

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

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

应用场合:

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

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

来源:https://www.cnblogs.com/ningjiabing/p/11829375.html

标签:MYSQL,主从复制
0
投稿

猜你喜欢

  • python 将numpy维度不同的数组相加相乘操作

    2022-03-26 06:14:06
  • Vue中的侦听器及使用场景

    2024-05-09 15:26:05
  • MySQL中把varchar类型转为date类型方法详解

    2024-01-27 03:15:01
  • SQL Server 存储过程解析

    2024-01-21 22:41:01
  • python实现mp3文件播放的具体实现代码

    2023-02-03 13:37:52
  • python GUI库图形界面开发之pyinstaller打包python程序为exe安装文件

    2021-03-29 23:02:58
  • Python tkinter三种布局实例详解

    2022-11-28 11:23:44
  • Go语言实战学习之流程控制详解

    2024-05-09 14:57:06
  • 重新restore了mysql到另一台机器上后mysql 编码问题报错

    2024-01-24 05:10:41
  • Django的用户模块与权限系统的示例代码

    2023-04-27 14:48:23
  • Python单元和文档测试实例详解

    2023-01-01 19:08:06
  • 聚焦 DreamWeaver MX 2004

    2010-03-25 12:22:00
  • Mysql中TIMESTAMPDIFF函数的语法与练习案例

    2024-01-28 18:43:44
  • MySQL的远程连接出现错误提示分析

    2011-07-01 11:34:00
  • 使用JavaScript获取地址栏参数的方法

    2024-04-28 10:18:25
  • 基于OpenCV和Gradio实现简单的人脸识别详解

    2022-10-21 22:59:11
  • python实现对服务器脚本敏感信息的加密解密功能

    2022-11-07 08:35:11
  • django+mysql的使用示例

    2022-10-24 20:34:15
  • Python如何实现远程方法调用

    2022-11-11 20:42:15
  • Python最长公共子串算法实例

    2022-08-11 01:29:57
  • asp之家 网络编程 m.aspxhome.com