0

0

Mysql复制(Replication)的实现_MySQL

php中文网

php中文网

发布时间:2016-06-01 13:42:03

|

1092人浏览过

|

来源于php中文网

原创

bitsCN.com Mysql复制(Replication)的实现 个人需要做一个小工程,需要将3台Mysql服务器的数据进行同步操作,经过上网查资料,并进行了实际操作完成了基本构思。         首先准备了3台Centos6.2,搭配了Apache Mysql PHP 等基本Webserver配置         3台机分别是Master A:192.168.1.49                              Slave   B1:192.168.1.50                                     B2:192.168.1.51         我需要的环境是单向复制,从复制A的数据到B1和B2.令3台机的数据一致。 配置逻辑:     从高层来看,复制分成三步:    (1)    master将改变记录到二进制日志(binary log)中(这些记录叫做二进制日志事件,binary log events);    (2)    slave将master的binary log events拷贝到它的中继日志(relay log);    (3)    slave重做中继日志中的事件,将改变反映它自己的数据。 开始配置:         第一步:创建复制帐号         每个slave使用标准的MySQL用户名和密码连接master。进行复制操作的用户会授予REPLICATIONSLAVE权限。     用户名的密码都会存储在文本文件master.info中。假如,你想创建repl用户,如下:         1mysql> GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.*2-> TO repl@'192.168.1.%' IDENTIFIED BY '123456';    第二步:配置My.cnf     配置Master的My.cnf,该文件默认位置为/etc/my.cnf         接下来对master进行配置,包括打开二进制日志,指定唯一的servr ID。例如,在配置文件加入如下值:        [mysqld]        log-bin=mysql-bin        server-id=10         重启master,运行SHOW MASTER STATUS,输出如下:  Mysql复制(Replication)的实现_MySQL            配置Slave的My.cnf,该文件默认位置为/etc/my.cnf         Slave的配置与master类似,你同样需要重启slave的MySQL。如下:         log_bin = mysql-bin         server_id = 2            relay_log = mysql-relay-bin         log_slave_updates = 1         read_only = 1         server_id是必须的,而且唯一。slave没有必要开启二进制日志,但是在一些情况下,必须设置,例如,如果slave为其它slave的master,必须设置bin_log。在这里,我们开启了二进制日志,而且显示的命名(默认名称为hostname,但是,如果hostname改变则会出现问题)。 relay_log配置中继日志,log_slave_updates表示slave将复制事件写进自己的二进制日志(后面会看到它的用处)。 
 有些人开启了slave的二进制日志,却没有设置log_slave_updates,然后查看slave的数据是否改变,这是一种错误的配置。所以,尽量使用read_only,它防止改变数据(除了特殊的线程)。但是,read_only并是很实用,特别是那些需要在slave上创建表的应用。     第三步:启动slave         接下来就是让slave连接master,并开始重做master二进制日志中的事件。你不应该用配置文件进行该操作,而应该使用CHANGE MASTER TO语句,该语句可以完全取代对配置文件的修改,而且它可以为slave指定不同的master,而不需要停止服务器。如下:1mysql> CHANGE MASTER TO MASTER_HOST='192.168.1.49',2    -> MASTER_USER='repl',3    -> MASTER_PASSWORD='123456',4    -> MASTER_LOG_FILE='mysql-bin.000001',5    -> MASTER_LOG_POS=0;        MASTER_LOG_POS的值为0,因为它是日志的开始位置。然后,你可以用SHOW SLAVE STATUS语句查看slave的设置是否正确: 01mysql> SHOW SLAVE STATUS/G02*************************** 1. row ***************************03                 Slave_IO_State:04                Master_Host: server105                Master_User: repl06                Master_Port: 330607              Connect_Retry: 6008            Master_Log_File: mysql-bin.00000109        Read_Master_Log_Pos: 410             Relay_Log_File: mysql-relay-bin.00000111              Relay_Log_Pos: 412      Relay_Master_Log_File: mysql-bin.00000113           Slave_IO_Running: No14          Slave_SQL_Running: No15                             ...omitted...16      Seconds_Behind_Master: NULL        Slave_IO_State, Slave_IO_Running, 和Slave_SQL_Running表明slave还没有开始复制过程。日志的位置为4而不是0,这是因为0只是日志文件的开始位置,并不是日志位置。实际上,MySQL知道的第一个事件的位置是4。 为了开始复制,你可以运行: 01mysql> START SLAVE;02mysql> SHOW SLAVE STATUS/G03运行SHOW SLAVE STATUS查看输出结果:04*************************** 1. row ***************************05             Slave_IO_State: Waiting for master to send event06                    Master_Host: server107                Master_User: repl08                Master_Port: 330609              Connect_Retry: 6010            Master_Log_File: mysql-bin.00000111        Read_Master_Log_Pos: 16412             Relay_Log_File: mysql-relay-bin.00000113              Relay_Log_Pos: 16414      Relay_Master_Log_File: mysql-bin.00000115           Slave_IO_Running: Yes16          Slave_SQL_Running: Yes17                             ...omitted...18      Seconds_Behind_Master: 0注意,slave的I/O和SQL线程都已经开始运行,而且Seconds_Behind_Master不再是NULL。日志的位置增加了,意味着一些事件被获取并执行了。如果你在master上进行修改,你可以在slave上看到各种日志文件的位置的变化,同样,你也可以看到数据库中数据的变化。 你可查看master和slave上线程的状态。在master上,你可以看到slave的I/O线程创建的连接: 01mysql> show processlist /G02*************************** 1. row ***************************03     Id: 104   User: root05   Host: localhost:209606     db: test    07Command: Query08   Time: 009 State: NULL10   Info: show processlist11*************************** 2. row ***************************12     Id: 213   User: repl14   Host: localhost:214415     db: NULL16Command: Binlog Dump17   Time: 1838    18 State: Has sent all binlog to slave; waiting for binlog to be updated19   Info: NULL202 rows in set (0.00 sec)基本到这里就完成,至于后期的加强操作,我会在另行添加。 测试过程要主要的问题:1.请先配置好Mysql2.开通复制前请将Mysql的库和表的框架复制过去。(在测试一下能不能连表都复制过去!)   作者 Tingel bitsCN.com

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

46

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

178

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

51

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

92

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

102

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

227

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

532

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

171

2026.03.04

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.6万人学习

Vue3.x 核心篇--十天技能课堂
Vue3.x 核心篇--十天技能课堂

共30课时 | 1.6万人学习

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

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