0

0

Mysql主从复制搭建_MySQL

PHP中文网

PHP中文网

发布时间:2016-05-27 13:45:13

|

1561人浏览过

|

来源于php中文网

原创

环境简介

主服务器: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

 

rpcms轻量开源内容管理系统3.3.3
rpcms轻量开源内容管理系统3.3.3

RPCMS是一款基于PHP+MYSQL的轻量型内容管理/博客系统,支持PHP5.6版本以上,支持win/Linux系统。它自主研发的RP框架(OPP方式),采用MVC架构搭建的高效、稳定的内容管理系统。灵活小巧,但有着强大的扩展性、丰富的插件接口和大量的模板。统一采用模板标签,轻松上手,让开发更方便!智能缓存机制让网站运行方面大幅度提高。系统特点:源码简洁、体积轻巧、功能丰富、安全、灵活等特点,完

下载
这里写图片描述

 

因为我的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)!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

32

2026.01.31

go语言 math包
go语言 math包

本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

23

2026.01.31

go语言输入函数
go语言输入函数

本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

16

2026.01.31

golang 循环遍历
golang 循环遍历

本专题整合了golang循环遍历相关教程,阅读专题下面的文章了解更多详细内容。

5

2026.01.31

Golang人工智能合集
Golang人工智能合集

本专题整合了Golang人工智能相关内容,阅读专题下面的文章了解更多详细内容。

6

2026.01.31

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

268

2026.01.31

高干文在线阅读网站大全
高干文在线阅读网站大全

汇集热门1v1高干文免费阅读资源,涵盖都市言情、京味大院、军旅高干等经典题材,情节紧凑、人物鲜明。阅读专题下面的文章了解更多详细内容。

195

2026.01.31

无需付费的漫画app大全
无需付费的漫画app大全

想找真正免费又无套路的漫画App?本合集精选多款永久免费、资源丰富、无广告干扰的优质漫画应用,涵盖国漫、日漫、韩漫及经典老番,满足各类阅读需求。阅读专题下面的文章了解更多详细内容。

170

2026.01.31

漫画免费在线观看地址大全
漫画免费在线观看地址大全

想找免费又资源丰富的漫画网站?本合集精选2025-2026年热门平台,涵盖国漫、日漫、韩漫等多类型作品,支持高清流畅阅读与离线缓存。阅读专题下面的文章了解更多详细内容。

85

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 820人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号