书籍详情
MySQL运维进阶指南
作者:贺春旸 著
出版社:机械工业出版社
出版时间:2022-11-01
ISBN:9787111712077
定价:¥109.00
购买这本书可以去
内容简介
本书以构建高性能MySQL服务器为核心,先介绍MySQL 8.0和MariaDB 10.5的新特性,然后以实战为导向,从故障诊断与优化、性能调优、备份与恢复、MySQL高可用集群搭建与管理、MySQL性能与服务监控、SQL自助上线等角度深入讲解了如何管理与维护MySQL服务器。书中内容均是基于笔者多年的实践经验整理而成,对于有代表性的疑难问题,还给出了实用的情景模拟以及解决方案。51CTO官方推荐 MySQL以其轻便、快捷、运营成本低等优点成为一款*受企业欢迎的数据库产品。贺春旸老师在MySQL领域深耕数十年,有着丰富的一线工作经验。日常在51CTO博客更文也是深受读者的喜欢,更是成为MySQL领域不可多得的博客专家。本书是贺春旸老师的又一佳作,他将多年实操经验融入字里行间,让读者能更快速理解并掌握知识点,在面对自己工作中实际问题时,如虎添翼、从容应对! ——51CTO博客(https://blog.51cto.com/)
作者简介
贺春旸 爱钱进DBA团队负责人,51CTO博客专家(讲师)、dbaplus社区专家,曾四次获得dbaplus年度MVP称号。从事MySQL数据库管理工作13年,曾任职于中国移动飞信、爱施德机锋网,主要负责数据库性能调优、监控和架构设计。擅长数据库设计评审、架构设计、性能调优、运维自动化管理等技术,有管理和维护高并发海量数据的经验,致力于MySQL、MariaDB、MongoDB等开源技术的研究。著有《MySQL管理之道:性能调优、高可用与监控》和《MySQL管理之道:性能调优、高可用与监控(第2版)》。dbaplus简介 数据连接未来!dbaplus是围绕Database、Bigdata、AiOps创建的企业级专业社群。汇集行业大咖、分享技术干货,每天精品原创文章推送,每周线上技术分享,每月线下技术沙龙,每季度Gdevops & DAMS行业大会。欢迎广大技术同路人加入dbaplus社群,共创学习交流、价值实现、跨界合作的平台。
目录
前言
第一部分 MariaDB与MySQL的新特性
第1章 MariaDB 10.5的新特性2
1.1 MariaDB概述2
1.2 MariaDB 10.5与MySQL 8.0的
比较3
1.2.1 存储引擎3
1.2.2 扩展和新功能4
1.3 如何将MySQL迁移至
MariaDB中5
1.4 MariaDB 10.5新特性详解7
1.4.1 客户端连接层的改进7
1.4.2 服务层的改进24
1.4.3 InnoDB存储引擎层的改进61
第2章 MySQL 8.0的新特性70
2.1 MySQL 8.0概述70
2.2 MySQL 8.0新特性详解70
2.2.1 性能提升73
2.2.2 客户端连接层的改进74
2.2.3 服务层的改进81
2.2.4 优化器的改进86
2.2.5 同步复制的改进104
2.2.6 InnoDB存储引擎层的改进110
2.2.7 通过pt-upgrade工具检测SQL
语法的兼容性122
第二部分 故障诊断与性能优化
第3章 故障诊断126
3.1 影响MySQL性能的因素126
3.2 系统性能评估标准127
3.2.1 影响Linux服务器性能的
因素128
3.2.2 系统性能评估指标129
3.2.3 开源监控和评估工具131
3.3 故障与处理136
3.3.1 基于pt-online-schema-change
修改表结构是否安全136
3.3.2 修改外键时,pt-osc内部是
如何处理的138
3.3.3 删除大表的小技巧139
3.3.4 重构Percona pt-archiver:轻松
归档大表数据140
3.3.5 Percona pt-kill改造版(PHP):
慢SQL报警及扼杀利器143
3.3.6 自适应Hash索引引起的
MySQL崩溃与重启146
3.3.7 诊断事务量突增的原因148
3.3.8 谨慎设置binlog_format=
MIXED150
3.3.9 MySQL故障切换之事件
调度器的注意事项155
3.3.10 误操作的恢复158
3.3.11 快速恢复二进制日志161
第4章 处理同步复制报错故障162
4.1 常见的3种故障162
4.1.1 在主库上删除一条记录导致
的故障163
4.1.2 主键重复164
4.1.3 在主库上更新了一条记录,
在从库上却找不到165
4.2 特殊情况:从库的中继日志受损166
4.3 多台从库中存在重复的server-id168
4.4 避免在主库上执行大事务169
4.5 slave_exec_mode参数可自动
处理同步复制错误169
4.6 如何验证主从数据是否一致171
4.7 binlog_ignore_db引起的同步
复制故障174
4.8 在从库上恢复指定表的简要
方法176
4.9 如何彻底清除从库的同步信息177
第5章 性能调优179
5.1 表的设计规范179
5.1.1 表的设计目标179
5.1.2 数据库三范式的定义180
5.2 字段类型的选取185
5.2.1 数值类型185
5.2.2 字符类型191
5.2.3 时间类型194
5.3 采用合适的锁机制201
5.3.1 表锁201
5.3.2 行锁203
5.3.3 行锁转表锁204
5.3.4 死锁205
5.4 选择合适的事务隔离级别207
5.4.1 事务的概念207
5.4.2 事务的实现208
5.4.3 事务的隔离级别210
5.5 SQL优化与合理利用索引218
5.5.1 慢查询的定位方法218
5.5.2 SQL优化案例分析219
5.5.3 合理使用索引230
5.6 my.cnf配置文件调优239
5.6.1 per_thread_buffers参数调优239
5.6.2 global_buffers参数调优241
5.6.3 查询缓存在不同环境下的
使用242
5.7 MySQL设计、开发和操作规范243
5.8 SQL自助上线平台254
5.8.1 简介254
5.8.2 审核规则256
第6章 备份与恢复258
6.1 冷备份259
6.2 逻辑备份259
6.2.1 mysqldump中增加了重要参数
--dump-slave260
6.2.2 取代mysqldump的新工具
mydumper261
6.3 热备份与恢复265
6.3.1 XtraBackup的工作原理265
6.3.2 使用Percona XtraBackup 8.0
备份MySQL 8.0269
6.3.3 MariaDB热备份工具
mariabackup270
第三部分 高可用架构
第7章 高可用架构集群管理272
7.1 MaxScale高可用架构273
7.1.1 功能概述273
7.1.2 搭建MaxScale高可用架构274
7.1.3 模拟故障转移279
7.2 MySQL组复制高可用架构282
7.2.1 组复制的工作原理283
7.2.2 组复制的特性和注意事项288
7.2.3 组复制的使用方法289
第8章 MySQL架构演进:一主
多从、读写分离294
8.1 实现读写分离的两种方式295
8.2 主从复制延迟的计算方法297
8.3 HAProxy感知MySQL主从同步
延迟300
8.4 搭建读写分离MariaDB MaxScale
架构307
8.4.1 配置环境及安装介绍307
8.4.2 基于连接方式的测试311
8.4.3 基于语句方式(SQL解析)
的测试311
8.4.4 MaxScale延迟检测312
第9章 TSpider分库分表的搭建与
管理316
9.1 TSpider简介317
9.1.1 TSpider的使用场景317
9.1.2 TSpider的取模扩容问题324
9.1.3 TSpider负载均衡架构设计325
9.2 Tdbctl详解325
9.2.1 安装Tdbctl组件326
9.2.2 Tdbctl的重要参数说明327
9.2.3 Tdbctl的配置管理327
9.2.4 Tdbctl组件的验证327
第四部分 监控管理平台
第10章 MySQL监控管理平台330
10.1 图形可视化监控工具MySQL
Monitor331
10.1.1 环境搭建334
10.1.2 搭建MySQL Monitor工具334
10.2 图形化显示慢日志的工具MySQL
Slowquery336
10.2.1 环境搭建337
10.2.2 MySQL Slowquery工具的
配置337
第一部分 MariaDB与MySQL的新特性
第1章 MariaDB 10.5的新特性2
1.1 MariaDB概述2
1.2 MariaDB 10.5与MySQL 8.0的
比较3
1.2.1 存储引擎3
1.2.2 扩展和新功能4
1.3 如何将MySQL迁移至
MariaDB中5
1.4 MariaDB 10.5新特性详解7
1.4.1 客户端连接层的改进7
1.4.2 服务层的改进24
1.4.3 InnoDB存储引擎层的改进61
第2章 MySQL 8.0的新特性70
2.1 MySQL 8.0概述70
2.2 MySQL 8.0新特性详解70
2.2.1 性能提升73
2.2.2 客户端连接层的改进74
2.2.3 服务层的改进81
2.2.4 优化器的改进86
2.2.5 同步复制的改进104
2.2.6 InnoDB存储引擎层的改进110
2.2.7 通过pt-upgrade工具检测SQL
语法的兼容性122
第二部分 故障诊断与性能优化
第3章 故障诊断126
3.1 影响MySQL性能的因素126
3.2 系统性能评估标准127
3.2.1 影响Linux服务器性能的
因素128
3.2.2 系统性能评估指标129
3.2.3 开源监控和评估工具131
3.3 故障与处理136
3.3.1 基于pt-online-schema-change
修改表结构是否安全136
3.3.2 修改外键时,pt-osc内部是
如何处理的138
3.3.3 删除大表的小技巧139
3.3.4 重构Percona pt-archiver:轻松
归档大表数据140
3.3.5 Percona pt-kill改造版(PHP):
慢SQL报警及扼杀利器143
3.3.6 自适应Hash索引引起的
MySQL崩溃与重启146
3.3.7 诊断事务量突增的原因148
3.3.8 谨慎设置binlog_format=
MIXED150
3.3.9 MySQL故障切换之事件
调度器的注意事项155
3.3.10 误操作的恢复158
3.3.11 快速恢复二进制日志161
第4章 处理同步复制报错故障162
4.1 常见的3种故障162
4.1.1 在主库上删除一条记录导致
的故障163
4.1.2 主键重复164
4.1.3 在主库上更新了一条记录,
在从库上却找不到165
4.2 特殊情况:从库的中继日志受损166
4.3 多台从库中存在重复的server-id168
4.4 避免在主库上执行大事务169
4.5 slave_exec_mode参数可自动
处理同步复制错误169
4.6 如何验证主从数据是否一致171
4.7 binlog_ignore_db引起的同步
复制故障174
4.8 在从库上恢复指定表的简要
方法176
4.9 如何彻底清除从库的同步信息177
第5章 性能调优179
5.1 表的设计规范179
5.1.1 表的设计目标179
5.1.2 数据库三范式的定义180
5.2 字段类型的选取185
5.2.1 数值类型185
5.2.2 字符类型191
5.2.3 时间类型194
5.3 采用合适的锁机制201
5.3.1 表锁201
5.3.2 行锁203
5.3.3 行锁转表锁204
5.3.4 死锁205
5.4 选择合适的事务隔离级别207
5.4.1 事务的概念207
5.4.2 事务的实现208
5.4.3 事务的隔离级别210
5.5 SQL优化与合理利用索引218
5.5.1 慢查询的定位方法218
5.5.2 SQL优化案例分析219
5.5.3 合理使用索引230
5.6 my.cnf配置文件调优239
5.6.1 per_thread_buffers参数调优239
5.6.2 global_buffers参数调优241
5.6.3 查询缓存在不同环境下的
使用242
5.7 MySQL设计、开发和操作规范243
5.8 SQL自助上线平台254
5.8.1 简介254
5.8.2 审核规则256
第6章 备份与恢复258
6.1 冷备份259
6.2 逻辑备份259
6.2.1 mysqldump中增加了重要参数
--dump-slave260
6.2.2 取代mysqldump的新工具
mydumper261
6.3 热备份与恢复265
6.3.1 XtraBackup的工作原理265
6.3.2 使用Percona XtraBackup 8.0
备份MySQL 8.0269
6.3.3 MariaDB热备份工具
mariabackup270
第三部分 高可用架构
第7章 高可用架构集群管理272
7.1 MaxScale高可用架构273
7.1.1 功能概述273
7.1.2 搭建MaxScale高可用架构274
7.1.3 模拟故障转移279
7.2 MySQL组复制高可用架构282
7.2.1 组复制的工作原理283
7.2.2 组复制的特性和注意事项288
7.2.3 组复制的使用方法289
第8章 MySQL架构演进:一主
多从、读写分离294
8.1 实现读写分离的两种方式295
8.2 主从复制延迟的计算方法297
8.3 HAProxy感知MySQL主从同步
延迟300
8.4 搭建读写分离MariaDB MaxScale
架构307
8.4.1 配置环境及安装介绍307
8.4.2 基于连接方式的测试311
8.4.3 基于语句方式(SQL解析)
的测试311
8.4.4 MaxScale延迟检测312
第9章 TSpider分库分表的搭建与
管理316
9.1 TSpider简介317
9.1.1 TSpider的使用场景317
9.1.2 TSpider的取模扩容问题324
9.1.3 TSpider负载均衡架构设计325
9.2 Tdbctl详解325
9.2.1 安装Tdbctl组件326
9.2.2 Tdbctl的重要参数说明327
9.2.3 Tdbctl的配置管理327
9.2.4 Tdbctl组件的验证327
第四部分 监控管理平台
第10章 MySQL监控管理平台330
10.1 图形可视化监控工具MySQL
Monitor331
10.1.1 环境搭建334
10.1.2 搭建MySQL Monitor工具334
10.2 图形化显示慢日志的工具MySQL
Slowquery336
10.2.1 环境搭建337
10.2.2 MySQL Slowquery工具的
配置337
猜您喜欢