首页 数据库 mysql教程 Mysql主从复制搭建_MySQL

Mysql主从复制搭建_MySQL

May 27, 2016 pm 01:45 PM
mysql 主从复制

环境简介

主服务器:CentOS6.5下mysql5.6.30

安装请参考这里网址:http://blog.csdn.net/hsd2012/article/details/51232612

从服务器:win7下5.6.17

原理简介及优缺点

MySQL从3.23版本开始提供复制功能,复制主要是指将主服务器的DDL和DML操作,通过二进制日志(binLog日志),传到服务的服务器上,然后在从服务器上对这些日志从新执行,从而实现从服务器与主服务器的数据同步。MySQL支持一台主服务器同时向多台从服务器进行复制,从服务器同时也可以作为其他服务器的主服务器,实现链状的复制。

优点

如果主服务器出现问题,可以快速切换到从服务器提供服务。 可以在从服务器上执行查询,降低主服务器的压力 可以在从服务器上执行备份,以避免备份期间影响主服务器的性能

局限

由于MySQL实现的是异步复制,所以主从服务器之间的数据存在一定差异,对实时性要求高的数据仍然需要从主服务器上获得。

前期准备

1.在linux下创建账号

在win的命令提示符中输入ipconfig,查看ip

 

这里写图片描述

 

因为我的win下ip为192.168.153.1,所以,我创建将Host设置为192.168.153.%,关于原因,可参考这里

 

这里写图片描述

 

2.赋予权限

 

这里写图片描述

 

REPLICATION SLAVE权限针对所有的数据库,只能通过. ,而不能shool.*,因为REPLICATION SLAVE是复制binlog日志。

 

这里写图片描述

 

3.将主服务器中的数据,复制到从服务器,确保两者搭建主从之前,数据一致。关于这,之前写过一篇文章专门介绍,可以参考这里

配置

主服务器配置

1.开启binlog日志,并设置server_id

 

这里写图片描述

 

从服务器配置

1.配置server_id

设置:server-id=2

 

这里写图片描述

 

2.指定主服务器配置格式如下

change master to

master_host=’master_host_name’, //从服务器的主机

master_user=’replication_user_name’,//执行复制用户名

master_password=’replication_password’,//执行复制用户密码

master_log_file=’recorded_log_file_name’,//二进制日志文件名

master_log_pos=’recorded_log_postion’;//复制开始位置

根据我的配置信息

bin-log信息

 

这里写图片描述

 

复制用户信息

 

这里写图片描述

 

我执行的配置代码如下:

change master to

master_host=’192.168.153.140’,

master_user=’lidequan’,

master_password=’lidequan’,

master_log_file=’bin-log.000003’,

master_log_pos=120;

 

这里写图片描述

 

查看从服务器是否已连接主服务器

执行start slave;

 

这里写图片描述

 

执行show processlist;

 

这里写图片描述

 

修改主服务器数据,查看同步效果

在这里修改主服务器数据,主要是执行插入,更新操作。

操作之前,数据信息如下

 

这里写图片描述

 

执行插入操作

insert into `class` (`name`) values ('三年二班'),('三年五班'),('三年七班');

 

这里写图片描述

 

此时从服务器中也有数据了

 

这里写图片描述

 

执行更新操作

update class set `name`='三年三班' where id=3;

观察下图,发现数据确实发生了变化

 

这里写图片描述

 

删除操作

观察下图,数据也是同步的

 

这里写图片描述

 

数据表定义操作

1.添加一个student表

CREATE TABLE student(

`id` INT(3) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT'学生编号',

`name` CHAR(10) NOT NULL DEFAULT '' COMMENT'学生名',

`class_id` INT(3) UNSIGNED NOT NULL DEFAULT 0 COMMENT'班级编号',

PRIMARY KEY(`id`)

) ENGINE=MYISAM DEFAULT CHARSET=utf8;

 

这里写图片描述

 

2.往student表中添加一个字段

ALTER TABLE student ADD COLUMN age TINYINT(2) UNSIGNED NOT NULL DEFAULT 0 COMMENT'学生年龄';

 

这里写图片描述

 

指定负责的数据库或者表

可以通过replicate-do-db、replicate-do-table、replicate-ignore-db、replicate-ignore-table或者replicate-wild-do-table来指定主从数据库复制到从数据库的数据库或者表。

关于数据复制的一些重要参数

在上面搭建主从服务器的时候,使用了MASTER_HOST,MASTER_PORT,MASTER_USER,MASTER_PASSWORD,MASTER_LOG_FILE,MASTER_LOG_POS这些参数都要在从服务器上配置,下面再来说几个常用的启动选项,如log_slave_updates、read_only、master_verify_checksum

log_slave_updates

log_slave_updates这个参数用来配置从服务器上的更新操作是否写入二进制日志,默认是不打开的。

首先我们来看一下刚刚win下mysql的binlog日志内容

 

这里写图片描述

 

可以发现,刚刚我们执行了增、删、改等操作,它并没有记录。

我们可以看到log_slave_updates是没有启动的

 

这里写图片描述

 

且该属性是只读属性,不可以动态的设置,只能在配置文件中设置,如下图设置将会报错

 

这里写图片描述

 

read_only

read-only选项:对所有的非临时表进行只读控制。但是有两种特殊情况

1. 对replication threads例外,以保证slave能够正常的进行replication。

2. 对于拥有super权限的用户,可以ignore这个选项。

 

这里写图片描述

 

当以没有拥有super权限的用户登录时候,会提示如下:

 

这里写图片描述

 

这样就确保了从数据只负责读数据操作,而拒绝写数据的操作。

补充:

SUPER 权限 :

1. 可以有change master to, kill其他用户的线程的权限。

2. Purge binary logs 来删除binary log, set global来动态设置变量的权限。

3. 执行mysqladmin debug命令,开启或者关闭log,在read-only打开时执行update/insert操作。

4. 执行start slave, stop slave.

5. 当连接数已经达到max_connections的最大值时,也可以连接到server。

master_verify_checksum

由于软硬件或者网络传输出错,导致主服务器上运行的sql语句与从服务器上运行的sql语句不一致,很难找到问题原因,mysql的开发人员在 5.6 Milestone Development Release版本中加入了 replication event checksum(主从复制事件校验)功能。master_verify_checksum主要用于复制事件校验。当一个event被写入binary log(二进制日志)的时候,checksum也同时写入binary log,然后在event通过网络传输到从服务器(slave)之后,再在从服务器中对其进行验证并写入从服务器的relay log。由于每一步都记录了event和checksum,所以我们可以很快地找出问题所在。

管理与维护

查看从服务器状态

使用show slave stauts;

 

这里写图片描述

 

在查看这些信息中,比较重要的是”slave_io_runing”和”slave_sql_runing”这两个进程

slave_io_runing :此进程负责从服务器从主服务器上读取Binlog日志,并写入从服务器上的中继日志中。

Slave_SQL_Runing:此进程负责读取并执行中继日志中的binlog日子。

只要期中有一个进程的状态时no,则表示复制进程停止。

总结

主从配置

一、主服务器上配置

1.创建用户,并赋予REPLICATION SLAVE权限

2.开启binlog日志,并设置server_id

二、从服务器配置

1.指定server_id

2.指定主服务器配置

备注:

1.win下mysql开启与关闭(前提是需要配置path路径)

 

这里写图片描述

 

2.server-id做什么用的

mysql的同步的数据中是包含server-id的,用于标识该语句最初是从哪个server写入的,所以server-id一定要有的,如果设置多个从服务器,每个从服务器必须有一个唯一的server-id值,必须与主服务器的以及其它从服务器的不相同。 每一个同步中的slave在master上都对应一个master线程,该线程就是通过slave的server-id来标识的;每个slave在master端最多有一个master线程,如果两个slave的server-id 相同,则后一个连接成功时,前一个将被踢掉。 在mysql做主从同步时,要保证一条数据不会陷入死循环,这里就是靠server-id来实现的。

 以上就是Mysql主从复制搭建_MySQL的内容,更多相关内容请关注PHP中文网(www.php.cn)!


本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
2 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP 的大数据结构处理技巧 PHP 的大数据结构处理技巧 May 08, 2024 am 10:24 AM

大数据结构处理技巧:分块:分解数据集并分块处理,减少内存消耗。生成器:逐个产生数据项,无需加载整个数据集,适用于无限数据集。流:逐行读取文件或查询结果,适用于大文件或远程数据。外部存储:对于超大数据集,将数据存储在数据库或NoSQL中。

如何在 PHP 中使用 MySQL 备份和还原? 如何在 PHP 中使用 MySQL 备份和还原? Jun 03, 2024 pm 12:19 PM

在PHP中备份和还原MySQL数据库可通过以下步骤实现:备份数据库:使用mysqldump命令转储数据库为SQL文件。还原数据库:使用mysql命令从SQL文件还原数据库。

如何优化 PHP 中的 MySQL 查询性能? 如何优化 PHP 中的 MySQL 查询性能? Jun 03, 2024 pm 08:11 PM

可以通过以下方式优化MySQL查询性能:建立索引,将查找时间从线性复杂度降至对数复杂度。使用PreparedStatements,防止SQL注入并提高查询性能。限制查询结果,减少服务器处理的数据量。优化连接查询,包括使用适当的连接类型、创建索引和考虑使用子查询。分析查询,识别瓶颈;使用缓存,减少数据库负载;优化PHP代码,尽量减少开销。

如何使用 PHP 插入数据到 MySQL 表中? 如何使用 PHP 插入数据到 MySQL 表中? Jun 02, 2024 pm 02:26 PM

如何将数据插入MySQL表中?连接到数据库:使用mysqli建立与数据库的连接。准备SQL查询:编写一个INSERT语句以指定要插入的列和值。执行查询:使用query()方法执行插入查询,如果成功,将输出一条确认消息。

如何使用 PHP 创建 MySQL 表? 如何使用 PHP 创建 MySQL 表? Jun 04, 2024 pm 01:57 PM

使用PHP创建MySQL表需要以下步骤:连接到数据库。创建数据库(如果不存在)。选择数据库。创建表。执行查询。关闭连接。

如何在 PHP 中使用 MySQL 存储过程? 如何在 PHP 中使用 MySQL 存储过程? Jun 02, 2024 pm 02:13 PM

要在PHP中使用MySQL存储过程:使用PDO或MySQLi扩展连接到MySQL数据库。准备调用存储过程的语句。执行存储过程。处理结果集(如果存储过程返回结果)。关闭数据库连接。

如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误 如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误 Dec 09, 2024 am 11:42 AM

MySQL 8.4(截至 2024 年的最新 LTS 版本)中引入的主要变化之一是默认情况下不再启用“MySQL 本机密码”插件。此外,MySQL 9.0完全删除了这个插件。 此更改会影响 PHP 和其他应用程序

oracle数据库和mysql的区别 oracle数据库和mysql的区别 May 10, 2024 am 01:54 AM

Oracle数据库和MySQL都是基于关系模型的数据库,但Oracle在兼容性、可扩展性、数据类型和安全性方面更胜一筹;而MySQL则侧重速度和灵活性,更适合小到中等规模的数据集。①Oracle提供广泛的数据类型,②提供高级安全功能,③适合企业级应用程序;①MySQL支持NoSQL数据类型,②安全性措施较少,③适合小型到中等规模应用程序。

See all articles