MYSQL的主从复制知识点整理
作者:ningjiabing 发布时间:2024-01-26 02:54:29
当单台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那么代码成功!完成!
说明:在配置成功之前,主服务器上的数据不会自动到从服务器上来。所以需要在配置之前先把主服务器上的所有数据先手动的导到从服务器上来,然后配置完主从之后,数据以后就同步了。
应用场合:
从服务器做为数据的备份服务器。当服务器压力比较大时可以使用主从服务器实现读、写分离来分流减轻服务器的压力。跨地域网站的优化
制作一个留言板的功能,考虑到不同地域优化的架构思路?
来源:https://www.cnblogs.com/ningjiabing/p/11829375.html
猜你喜欢
- Python单例模式的两种实现方法方法一 import threading class Singleton(object): &
- 中介者模式中介者模式(Mediator Pattern)是一种常用的设计模式,用于解决各个对象之间的复杂依赖关系,使得各个对象之间可以独立地
- 核心代码:ALTER TABLE 表名 AUTO_INCREMENT = 设定的值 MySQL ALTER语法中ALTER [IGNORE]
- 在Windows下安装MySQL ,用了官方的配置向导生成了my.ini,本以为很安稳了,谁知十多个小时过去之后,系统响应非常慢,看资源管理
- 开篇:测试过程中,对于多参数参数多值的情况进行测试用例组织,之前一直使用【正交分析法】进行用例组织,说白了就是把每个参数的所有值分别和其他参
- 最近要做一个网站需要用到天气预报,本来是想找到API,自己写一个自己的天气预报小程序的,没有成功,只好去找现成的代码调用。经过测
- function clickButton(id) { &n
- 本文实例讲述了python读取word文档的方法。分享给大家供大家参考。具体如下:首先下载安装win32comfrom win32com i
- 目的:Python 格式化打印json数据方法(展开状态)环境:系统:Win10 x64环境:PycharmPython 3.7.0问题分析
- 在WEB开发中.我们可能都习惯使用下面的代码来获取客户端的IP地址: C#代码 //优先取得 * string IP = Request
- MS SQL性能是很不错的,但是数据库用了一段时间之后,数据库却变得很大,实际的数据量不大。一般都是数据库日志引起的!数据库日志的
- 自定义分页样式,不多废话,直接上代码~ html部分<div id="my_id"> &nbs
- 前言刚刚看了EuroPython 2017一篇演讲,Why You Don't Need Design Patterns in Py
- 导语由于之前遇到过几次有关于参数类型的坑,以及经常容易把一些参数类型搞混淆,现在做一下有关参数类型的总结记录以及对之前踩坑经历的分析。参数类
- 1.Go语言String的本质就是一个[]byte,所以他们之间可以互相转换,byte数组的长度就是字符串的长度。func StringTe
- 关系型数据库:关系型数据库的优势:保持数据的一致性(事务处理)由于以标准化为前提,数据更新的开销很小(相同的字段基本上都只有一处)可以进行J
- 一. torch.cat()函数解析1. 函数说明1.1 官网:torch.cat(),函数定义及参数说明如下图所示:1.2 函数功能函数将
- 有时我们用pycharm打开某个文件的时候,默认的打开方式是不正确的,那么如何设置呢?下面小编给大家分享一下。首先我们点击File菜单,然后
- Queue模块保持线程同步利用Queue对象先进先出的特性,将每个生产者的数据一次存入队列,而每个消费者将依次从队列中取出数据import
- 在 golang 语言中,实现io的读与写,只要实现了如下的读写接口即可:// go 1.19/src/io/io.go