| 作者 |
| 罗小波 |
| 丛书名 |
| 出版社 |
| 电子工业出版社 |
| ISBN |
| 9787121397141 |
| 简要 |
| 简介 |
| 内容简介书籍计算机书籍 全书共分为 3 篇:基础篇、方案篇和参考篇,按照“基本原理”→“生产实践”→“更多参考”的逻辑顺序讲述,书中配了大量的原理与方案示意图,力求用通俗易懂的语言、直观明了的示意图、完整的知识涵盖面将 MySQL 的复制技术讲透。其中,基础篇侧重介绍主从复制的原理和复制技术的演进,方案篇侧重介绍主从复制技术在生产环境中的应用方案,参考篇侧重介绍二进制日志的基本组成以及主从复制中常见对象复制的安全性等。 |
| 目录 |
| 基 础 篇 第1章 复制的概述 2 1.1 适用场景 2 1.2 数据同步方法 3 1.3 数据同步类型 4 1.4 复制格式 4 第2章 复制的基本原理 6 2.1 概述 6 2.2 细节 7 第3章 复制格式详解 10 3.1 复制格式概述 10 3.2 复制格式明细 11 3.2.1 基于STATEMENT和基于ROW的复制的优缺点 11 3.2.2 使用ROW格式的二进制日志进行复制 14 3.3 如何确定与记录复制中的安全和不安全语句 15 第4章 传统复制与GTID复制 18 4.1 传统复制 18 4.2 GTID复制 19 4.2.1 GTID的格式和存储 19 4.2.2 GTID的生命周期 23 4.2.3 GTID 自动定位 26 4.2.4 GTID复制模式的限制 27 第5章 半同步复制 29 5.1 半同步复制的原理 29 5.2 半同步复制的管理接口 33 5.3 半同步复制的监控 33 5.4 半同步复制的注意要点 34 第6章 多线程复制 36 6.1 单线程复制原理 36 6.2 DATABASE多线程复制 38 6.2.1 原理 38 6.2.2 系统变量的配置 40 6.3 LOGICAL_CLOCK多线程复制 40 6.3.1 原理 40 6.3.2 系统变量的配置 42 6.4 WRITESET多线程复制 42 6.4.1 原理 42 6.4.2 系统变量的配置 50 第7章 多源复制 51 7.1 复制通道 51 7.2 单通道操作命令 52 7.3 复制语句的向前兼容性 53 7.4 启动选项和复制通道选项 53 7.5 复制通道的命名约定 55 第8章 从库中继日志和状态日志 56 8.1 中继日志和状态日志概述 56 8.2 从库中继日志 57 8.3 从库状态日志 58 第9章 通过PERFORMANCE_SCHEMA库检查复制信息 66 9.1 PERFORMANCE_SCHEMA库中的复制信息记录表概述 66 9.2 PERFORMANCE_SCHEMA库中的复制信息记录表详解 70 9.2.1 REPLICATION_APPLIER_CONFIGURATION表 70 9.2.2 REPLICATION_APPLIER_STATUS表 71 9.2.3 REPLICATION_APPLIER_STATUS_BY_COORDINATOR表 72 9.2.4 REPLICATION_APPLIER_STATUS_BY_WORKER表 74 9.2.5 REPLICATION_CONNECTION_CONFIGURATION表 76 9.2.6 REPLICATION_CONNECTION_STATUS表 78 9.2.7 REPLICATION_GROUP_MEMBER_STATS表 80 9.2.8 REPLICATION_GROUP_MEMBERS表 81 第10章 通过其他方式检查复制信息 83 10.1 复制状态变量 83 10.2 复制心跳信息 83 10.3 SHOW SLAVE STATUS语句输出信息详解 85 10.4 通过SHOW PROCESSLIST语句查看复制线程状态 92 10.5 SHOW MASTER STATUS语句输出详解 93 10.6 SHOW SLAVE HOSTS语句 93 第11章 MYSQL复制延迟SECONDS_BEHIND_MASTER究竟是如何计算的 96 11.1 “口口相传”的计算方法 96 11.2 探寻“正确”的计算方法 97 11.3 验证 100 11.3.1 我们想确认什么 100 11.3.2 提前确认一些信息 100 11.3.3 执行验证 102 11.4 小结 103 第12章 如何保证从库在意外中止后安全恢复 104 12.1 从库的崩溃与恢复概述 104 12.2 从库的崩溃与恢复详解 104 12.2.1 单线程复制的安全恢复 104 12.2.2 多线程复制的安全恢复 105 第13章 MYSQL SERVER复制过滤 108 13.1 MYSQL SERVER复制过滤规则概述 108 13.2 库级别复制过滤选项的评估 109 13.3 表级别复制过滤选项的评估 113 13.4 复制过滤规则的应用 115 方 案 篇 第14章 搭建异步复制 120 14.1 操作环境信息 120 14.2 全新初始化场景 121 14.2.1 传统复制 121 14.2.2 GTID复制 124 14.3 已有数据场景 126 14.3.1 传统复制 127 14.3.2 GTID复制 134 14.4 变量模板 140 14.4.1 传统复制模式的变量模板 140 14.4.2 GTID复制模式的变量模板 144 第15章 搭建半同步复制 146 15.1 半同步复制插件的安装和配置环境要求 146 15.2 半同步复制插件的安装和配置 147 15.2.1 关键步骤 147 15.2.2 详细过程 148 15.3 半同步复制工作状态的验证 152 第16章 通过扩展从库以提高复制性能 155 16.1 操作环境 155 16.2 横向扩展 156 16.2.1 扩展从库的简要步骤 157 16.2.2 扩展从库的详细过程 158 16.2.3 配置从库的读负载均衡 164 16.3 提高复制性能 165 第17章 复制模式的切换 167 17.1 操作环境信息 167 17.2 复制模式的相关概念 167 17.3 传统复制在线变更为GTID复制 173 17.3.1 简要步骤 173 17.3.2 详细过程 173 17.4 GTID复制在线变更为传统复制 179 17.4.1 简要步骤 179 17.4.2 详细过程 180 17.5 GTID复制离线变更为传统复制 186 17.5.1 简要步骤 186 17.5.2 详细过程 187 17.6 传统复制离线变更为GTID复制 191 17.6.1 简要步骤 191 17.6.2 详细过程 191 第18章 复制拓扑的在线调整 196 18.1 操作环境信息 196 18.2 传统复制模式下的复制拓扑在线调整 197 18.2.1 并行复制变更为串行复制 198 18.2.2 串行复制变更为并行复制 206 18.3 GTID复制模式下的复制拓扑在线调整 211 18.3.1 并行复制变更为串行复制 212 18.3.2 串行复制变更为并行复制 214 第19章 主从实例的例行切换 218 19.1 操作环境信息 218 19.2 在线切换 219 19.2.1 基于账号删除的在线切换 220 19.2.2 基于修改连接数的在线切换 232 第20章 数据库故障转移 239 20.1 操作环境信息 240 20.2 主库故障转移的关键步骤 241 20.3 主库故障转移的详细过程 243 20.3.1 环境的准备 243 20.3.2 执行步骤 245 第21章 搭建多源复制 255 21.1 操作环境信息 255 21.2 基于传统复制的多源复制 256 21.2.1 传统复制模式下的单线程多源复制 256 21.2.2 传统复制模式下的多线程多源复制 261 21.3 基于GTID复制的多源复制 263 21.3.1 GTID复制模式下的单线程多源复制 264 21.3.2 GTID复制模式下的多线程多源复制 267 21.4 多源复制拓扑中复制相关的操作语句变化 268 第22章 MYSQL版本升级 273 22.1 MYSQL版本之间的复制兼容性 273 22.2 升级复制的设置 274 第23章 将不同数据库的数据复制到不同实例 276 23.1 操作环境信息 276 23.2 通过设置复制过滤规则将不同数据库的数据复制到不同实例 277 23.2.1 通过只读选项配置复制过滤规则 278 23.2.2 通过动态语句配置复制过滤规则 286 第24章 发生数据误操作之后的处理方案 293 24.1 操作环境信息 294 24.2 主库发生误操作后的数据恢复 295 24.2.1 通过延迟复制恢复数据 296 24.2.2 通过闪回工具恢复数据 302 24.3 从库发生误操作后的数据恢复 309 24.3.1 通过修改系统变量SLAVE_EXEC_MODE恢复数据 309 24.3.2 通过GTID特性注入空事务恢复数据 316 第25章 常用复制故障排除方案 323 25.1 确认故障现象 323 25.2 信息收集与故障排查 323 25.3 复制故障的修复 325 25.4 无法解决的问题 326 参 考 篇 第26章 二进制日志文件的基本组成 328 26.1 什么是二进制日志 328 26.2 二进制日志的组成 328 26.3 二进制日志内容解析 329 26.3.1 基于ROW的复制的二进制日志内容解析 330 26.3.2 基于STATEMENT的复制的二进制日志内容解析 344 26.4 小结 351 第27章 常规DDL操作解析 352 27.1 操作环境信息 352 27.2 常规DDL操作示例 353 27.3 二进制日志内容解析 356 27.4 小结 359 第28章 为何二进制日志中同一个事务的事件时间点会乱序 360 28.1 操作环境信息 360 28.2 验证前的准备 360 28.3 验证过程 361 第29章 复制AUTO_INCREMENT字段 367 29.1 操作环境信息 367 29.2 复制AUTO_INCREMENT字段的操作示例 367 29.3 对二进制日志的解析及解释 368 29.3.1 基于ROW的复制中AUTO_INCREMENT字段的复制 368 29.3.2 基于STATEMENT的复制中AUTO_INCREMENT字段的复制 369 29.3.3 混合复制中AUTO_INCREMENT字段的复制 371 29.4 使用AUTO_INCREMENT字段时的注意事项 371 29.5 小结 372 第30章 复制CREATE ... IF NOT EXISTS语句 373 30.1 操作环境信息 373 30.2 复制CREATE ... IF NOT EXISTS语句的操作演示 374 30.3 二进制日志解析结果的解释 375 30.4 小结 376 第31章 复制CREATE TABLE ... SELECT语句 377 31.1 操作环境信息 377 31.2 复制CREATE TABLE ... SELECT语句的操作示例 377 31.3 二进制日志的解析及解释 380 31.3.1 STATEMENT格式二进制日志的解析及解释 380 31.3.2 ROW格式和MIXED格式二进制日志的解析及解释 381 31.4 使用CREATE TABLE ... SELECT语句时的注意事项 384 31.5 小结 384 第32章 在主从复制中使用不同的表定义 385 32.1 操作环境信息 385 32.2 主从库的表字段数不同时如何复制 386 32.2.1 源表字段数多于目标表字段数 386 32.2.2 目标表字段数多于源表字段数 388 32.3 不同类型字段的复制 389 32.3.1 属性提升 390 32.3.2 有损转换与无损转换 390 32.4 小结 391 第33章 复制中的调用功能 392 33.1 操作环境信息 392 33.2 复制中的调用功能操作示例 392 33.2.1 在READ-COMMITTED隔离级别、基于ROW的复制场景下数据库的 操作记录 393 33.2.2 在READ-COMMITTED隔离级别、基于STATEMENT的复制场景下 数据库的操作记录 396 33.3 二进制日志的解析及解释 396 33.3.1 ROW和MIXED格式二进制日志的解析及解释 396 33.3.2 STATEMENT格式二进制日志的解析及解释 402 33.4 小结 407 第34章 复制LIMIT子句 408 34.1 操作环境信息 408 34.2 复制LIMIT子句的操作示例 408 34.3 二进制日志的解析及解释 409 34.3.1 STATEMENT格式二进制日志的解析及解释 410 34.3.2 ROW格式和MIXED格式二进制日志的解析及解释 411 34.4 小结 414 第35章 复制LOAD DATA语句 415 35.1 操作环境信息 415 35.2 复制LOAD DATA语句的操作示例 416 35.2.1 准备演示数据 416 35.2.2 LOAD DATA语句的操作 417 35.3 二进制日志的解析及解释 417 35.3.1 STATEMENT格式二进制日志的解析及解释 417 35.3.2 ROW格式和MIXED格式二进制日志的解析及解释 419 35.4 小结 420 第36章 系统变量MAX_ALLOWED_PACKET对复制的影响 421 36.1 系统变量简介 421 36.2 操作环境信息 422 36.3 MAX_ALLOWED_PACKET对复制的影响操作示例 423 36.3.1 MAX_ALLOWED_PACKET对主库的影响 423 36.3.2 MAX_ALLOWED_PACKET对从库的影响 424 36.4 小结 427 第37章 复制临时表 429 37.1 操作环境信息 429 37.2 复制临时表的操作示例 429 37.2.1 基于STATEMENT的复制且隔离级别为REPEATABLE-READ 430 37.2.2 基于ROW的复制且隔离级别为REPEATABLE-READ 432 37.2.3 混合复制且隔离级别为REPEATABLE-READ 433 37.2.4 使用临时表时如何安全关闭从库 433 37.3 与临时表相关的其他注意事项 435 37.4 小结 435 第38章 复制中的事务不一致问题 436 38.1 事务不一致的场景类型 436 38.2 事务不一致的原因 437 38.3 事务不一致的后果 437 38.4 小结 438 |