MySQL 8.0原理与实战一网打尽,甲骨文数据库专家硬刚5年之作

news2025/3/1 16:18:47

根据权威数据库技术排名网站DB-Engines今年4月的最新数据,MySQL是全球最流行的开源数据库,没有之一。在所有数据库排名中,MySQL仅次于Oracle,“屈居”亚军之位。但大家从截图中可以看出,MySQL与Oracle的得分差距已经非常小了。
图片

“开源壮年”数据库MySQL自1995年发布1.0版本以来,迄今已经走过了28个年头。从诞生之初的“玩具型”数据库,到如今互联网行业的事实标配,它之所以流行,可归结为以下几点。

  1. 开源免费:MySQL是一个开源的数据库管理系统,不仅性能卓越,而且是完全免费的,对于个人开发者和中小企业非常友好。

  2. 多语言支持:MySQL支持多种编程语言,包括PHP、Java、Python等,极大地扩展了MySQL的适用范围。

  3. 高性能:MySQL能够提供出色的性能,并能够灵活地适应多种应用场景和业务需求。

  4. 可扩展性:MySQL可以轻松地扩展集群和数据库复制,使得其能够适应不断增加的数据存储需求。

  5. 可移植性:MySQL支持多种操作系统,例如Windows、Linux、UNIX等,这使得MySQL在不同的操作平台上具有高度的可移植性。

  6. 社区支持:MySQL拥有庞大的社区支持,提供了丰富的文档、工具、插件、示例等资源,为用户提供了更加便利的开发和维护环境。

总结为一句话,开源、简单、易用,高性能、可扩展、可移植,以及社区强大的支持——哪个开发者不爱这样的数据库呢?哪个中小企业不爱这样的数据库呢?
目前,生产上用得比较多的是MySQL 5.6和MySQL 5.7。大家也知道,2023年10月,MySQL 5.7将停止更新,结束其生命周期,而MySQL 5.6在2年前就停更了。一句话,迁移到MySQL 8.0势在必行,而充分利用MySQL 8.0的新特性提高生产力就成为重中之重。
图片

怎么办?网络上的信息是如此零散和碎片化,而市面上MySQL相关的书一般版本较老,大部分还是基于MySQL 5.6和MySQL 5.7。
凉拌?大可不必。推荐一本帮助大家解决燃眉之急的新书。既聚焦MySQL 8.0相关问题,又深度解读常用工具和常用操作原理!
而非常关键的是,这本新书出自目前担任甲骨文首席工程师,拥有10多年数据库管理和架构经验的陈臣老师。本书的写作历时五年,三易其稿,现在终于跟大家见面了,它不像ChatGPT,给你的解决方案好看不够好用,偶尔还能一本正经地捏造(而你找bug还挺费劲儿),本书给出的是完整、细致、靠谱、可落地的解决方案。
图片

本书基于MySQL 8.0,不仅介绍了可以拿来即用的实战内容,还专门剖析了各个操作背后的实现原理,让你不仅知其然,也知其所以然。此外,每章最后还会通过列出问题的方式梳理重点,不仅可以用来检验对内容的掌握程度,也可以作为很好的面试题。

本 书 内 容

本书以MySQL 8.0为主,全面系统地阐述了 MySQL 日常使用及管理过程中的一些常用知识点:安装、复制、binlog、备份、监控、DDL、线程池、中间件、常用工具、组复制、InnoDB Cluster、JSON、MySQL 8.0 的新特性。
本书定位于实战,目的是让读者拿来即用,快速上手 MySQL。除了实战,本书还花费了大量的篇幅来讲解 MySQL 中一些常见操作、常用工具的实现原理。
组复制是 MySQL 官方推荐的高可用方案,本书会从源码角度分析组复制的一些核心模块的实现细节,包括分布式恢复、冲突检测、事务一致性以及流量控制机制等。
大家通过下面的思维导图可以查看本书的内容。
图片

本书一共12章,各章内容如下。
第1章介绍了 MySQL 的两种常用安装方法以及两种常用的MySQL 服务管理方式。

第2章从复制的基本原理出发,系统介绍了 GTID 复制、半同步复制、并行复制、多源复制和延迟复制。

第3章首先分析了 binlog 的3种格式及其优缺点,接着演示了如何阅读 binlog 和 relay log 中的内容,然后介绍了 binlog 中常见的事件类型,最后基于 python-mysql-replication 打造了一个 binlog 解析器。

第4章主要介绍了常用的复制管理操作,复制的监控,如何分析主从延迟,主从延迟的常见原因及解决方法 Seconds_Behind_Master 的计算逻辑,如何监控主从延迟,复制中的常见问题及解决方法。

第5章首先介绍了 MySQL 常见备份工具的具体用法及实现原理,然后介绍了与备份相关的两个高频操作,最后介绍了如何搭建 binlog server 以及如何检测备份的有效性。

第6章介绍了业界流行的两个开源监控方案——Zabbix 和基于 Prometheus 开发的 PMM,以及 MySQL 中常用的监控指标。

第7章首先介绍了3种常用的表结构变更方式——Online DDL、pt-online-schema-change和 gh-ost,接着介绍了元数据锁的基本概念和引入背景,最后分析了如何定位 DDL 被阻塞的问题。

第8章围绕连接池和线程池展开介绍。

第9章介绍了 MySQL 中一些常用工具的具体用法及实现原理。

第10章介绍了中间件 ProxySQL。

第11章系统介绍了组复制的引入背景、部署、监控和常见的管理操作,并且基于源码分析了组复制一些核心模块的实现细节。

第12章系统介绍了 InnoDB Cluster 的两大核心组件:MySQL Shell 和 MySQL Router。

本 书 特 色

  1. 实战性强:案例丰富且可移植性强,拿来即用。
  2. 原理深入浅出:快速掌握 MySQL 常见操作的实现原理。
  3. 源码解析:从源码角度理解组复制核心模块的实现细节。
  4. 作者靠谱:甲骨文首席工程师,“MySQL实战”公众号作者倾力打造。

图片

业内大咖力荐

我们有幸邀请到国内顶尖大佬
谢鹏|叶金荣|沈剑
周彦伟|肖博|彭立勋
提前阅读了本书
并且分享了他们的专家书评
图片

MySQL 是流行的开源数据库。陈臣所著的《MySQL实战》是基于他自己的大规模数据库管理实践,结合源码、官方文档和原理形成的一本书,系统地介绍了在 MySQL 的管理、运维和开发过程中使用范围较广但参考资料匮乏的工具。
——谢鹏
甲骨文(Oracle)公司全球副总裁
中国区技术总经理
看完这本书的目录及样章,深感陈臣满满的诚意。全书紧紧围绕 MySQL 实战的方方面面展开,有详细的实战细节,更是对几个关键知识点给了原理解读,让读者能更好地理解,知其然且知其所以然。以“组复制”这一章为例,前半部分详细演示了组复制的部署及管理操作,后半部分详细分析了组复制的一些关键实现原理,其中原理解读部分占了该章60%以上的篇幅,详细程度可见一斑。强烈推荐这本书,绝对值得一看。
——叶金荣
Oracle MySQL ACE Director
腾讯云TVP成员
读完样章,内容让人惊艳:GTID 的原理与并行复制,主从原理与 binlog 细节,XtraBackup 的巧妙原理,连接池与线程池,中间件的运用实践,包括最新的组复制实践……沉下心,嚼碎这些内容,我相信你一定能超越九成的 MySQL 从业人员。感谢陈臣的诚意之作,让大家学习MySQL又多了一个选择。行业内能有这样的技术匠人,幸甚至哉!
——沈剑
公众号“架构师之路”作者
拿到这本书的书稿后,既觉得是意料之中,又确实出乎了意料。这本书算得上近年来国内 MySQL 领域出版物中内容十分丰富、细节十分清晰、篇幅也是相当长的,其运维实践与源码解析相结合的思路正与《MySQL运维内参》不谋而合,不愧为实战之作。
——周彦伟
极数云舟创始人
《MySQL运维内参》作者
中国计算机行业协会数据库专委会会长
这本书不仅包含了MySQL的实战操作和对应的理论知识,还包含了 MySQL 的一些非常实用的周边工具和中间件,实属难得。不论对于数据库初学者还是有经验者,这本书都值得反复研读,实践是检验真理的唯一标准。
——肖博
vivo研发总监
陈臣是奋战在运维一线的 DBA 专家,见证过大型数据库平台从零开始建设的过程。他从一个数据库运维人员的角度帮大家把 MySQL 的整个运维体系梳理了出来,书中不仅介绍了 MySQL 的原理、使用方法,更重要的是贡献出了他自己的经验,包括对 MySQL 生态的周边工具、中间件、连接池等的介绍和使用经验。这些经验十分宝贵。非常推荐 MySQL DBA 们阅读一下这本书,无论对于新手入门还是老手进阶,这本书都是不错的参考。
——彭立勋
ACMUG(中国MySQL用户组)主席
Oracle MySQL ACE Director
此外,MySQL 业界大佬吴炳锡老师在阅读完该书的部分章节后,也表示:“2023年了,《MySQL实战》这本书还是值得推荐的。”

本书适合人群

图片

关于作者陈臣

图片

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/426379.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【C语言】分支语句和循环语句(上)

【C语言】分支语句和循环语句(上)前言1.分支语句和循环语句2.什么是语句3.分支语句(选择语句)3.1 if语句3.1.1 悬置else3.1.2 if的书写形式对比3.1.3 在线练习3.2 switch语句3.2.1 switch语句中的break的作用3.2.2 default子句3.2…

记一次csdn图片访问失败问题

前言 家里电脑写博客 一直图片查看不了 以为csdn问题 后来发现可能是网络的问题 公司电脑访问都是正常的,并且换个浏览器也是一样 记录一下排查过程 过程 法1 chrome 关闭对csdn不安全访问 回归一下 可能要找img-blog.csdnimg.cn这个地址的试一下 法2 换dns …

Linux:centos 关闭 防火墙 关闭SELinux 配置临时ip

1.关闭防火墙 systemctl status firewalld.service 查看防火墙状态 这个是运行中,使用 systemctl stop firewalld.service 临时关闭防火墙 这个样子的话重启之后就会再次自动开启防火墙 systemctl disable firewalld.service 永久关闭防火墙 然后重启centos 可以看…

【Python实战】2022年中国富豪榜出炉,首富竟是他......教你一键采集榜单并做可视化效果图(今天是拉仇恨的一天鸭~)

前言 哈喽,我是你们的栗子同学~ 今天是拉仇恨的一天: 教大家一键采集(爬虫数据分析基础实战)新CaiFu中国500富人榜,中国首富竟然是他...... 所有文章完整的素材源码都在👇👇 粉丝白嫖源码福利…

深度学习入门之感知机

一. 感知机的定义 感知机接收多个输入信号,输出一个信号。这里所说的“信号”可以想象成电流或河流那样具备“流动性”的东西。像电流流过导线,向前方输送电子一样,感知机的信号也会形成流,向前方输送信息。但是,和实…

后缀数组的应用:在哪个位置插入字符串使得字典序最大

题目描述 给定两个字符串 str1 和 str2,想把 str2 整体插入到 str1 中某个位置,形成最大的字典序,返回字典序最大的结果。其中 str1 长度为 NNN, str2 长度为 MMM,且 N>>MN >> MN>>M。 思路分析 …

【排序算法 下】带你手撕常见排序 (冒泡,快排,归并排序) (动图详解)

欢迎来到 Claffic 的博客 💞💞💞 “只要有花可开,就不允许生命与黯淡为伍。” 前言: 承接上篇,继续带大家手撕常见排序算法,这次讲剩余的两类:交换排序和归并排序。 注:…

C++——模板初阶与泛型编程

文章目录💐专栏导读💐文章导读🌷引例🌷函数模板🌺函数模板的概念🌺函数模板的格式🌷函数模板的原理🌷函数模板的实例化🌺隐式实例化🌺显式实例化&#x1f33a…

Maven安装

目录 1.Maven安装 1.1下载 1.2 安装步骤 1、解压 apache-maven-3.6.1-bin.zip(解压即安装) 2、配置本地仓库 3、配置阿里云私服 4、配置环境变量 1.3 安装检测 1.Maven安装 认识了Maven后,我们就要开始使用Maven了,那么首…

基于OpenCv的图像分割(分水岭算法)

文章目录图像分割distanceTransform()connectedComponents()watershed()查看图像的矩阵图像分割 图像分割对于图像处理和计算机视觉领域非常重要,可以用于对象识别、图像分析、图像压缩等应用。 注意:通常我们把前景目标的灰度值设为255,即白…

网络原理与网络通信

目录 网络互连原理 网络通信 IP地址和端口号 网络协议 五元组 协议分层 OSI七层模型 TCP/IP五层模型 封装和分用 网络互连原理 计算机在最开始的时候是没有网络的,每个计算机之间相互独立。这样处理信息就非常的麻烦,为了能够更高效的利用计算…

一个基于Java线程池管理的开源框架Hippo4j实践

文章目录概述定义线程池痛点功能框架概览架构部署Docker安装二进制安装运行模式依赖配置中心接入流程个性化配置线程池监控无中间件依赖接入流程服务端配置三方框架线程池适配拒绝策略自定义概述 定义 Hippo4j 官网地址 https://hippo4j.cn/ 最新版本1.5.0 Hippo4j 官网文档地…

硬件系统工程师宝典(17)-----你的PCB符合工艺要求吗?

各位同学大家好,欢迎继续做客电子工程学习圈,今天我们继续来讲这本书,硬件系统工程师宝典。上篇我们说到PCB设计中板子要符合EMC,信号的走线要平顺,信号回流阻抗尽量小。今天我们开始看看板子在生产制造时的工艺问题。…

【安全防御】防火墙(二)

目录 1、防火墙如何处理双通道协议 2、防火墙如何处理nat 3、防火墙支持哪些NAT,主要应用的场景是什么? 4、当内网PC通过公网域名解析访问内网服务器的时候,会存在什么问题,如何解决?请详细说明 5.防火墙使用VRRP…

面试题总结-JS

文章目录一、JS 系列1、原型、原型链2、闭包3、this指向4、call、 apply、 bind 的作用与区别?5、数组扁平化6、var、let、const 区别7、对称加密和不对称加密的区别8、js 的栈和堆9、对象的深拷贝和浅拷贝10、浏览器的事件循环机制11、宏任务和微任务12、script 标…

StringBuilder、StringBuffer、String的区别

StringBuilder与StringBuffer的append方法源码分析 #mermaid-svg-N8145OzAyMWzlewt {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-N8145OzAyMWzlewt .error-icon{fill:#552222;}#mermaid-svg-N8145OzAyMWzlewt .er…

C#基础学习--泛型

目录 C#中的泛型 泛型类 声明泛型类 创建构造函数 创建变量和实例 类型参数的约束 Where 子句 泛型方法 声明泛型方法 ​编辑 调用泛型方法 扩展方法和泛型类 泛型结构 泛型委托 泛型接口 协变 逆变 接口的协变和逆变 C#中的泛型 泛型允许我们声明 类型参数化 的代码&…

Jetpack Compose大师乘势而上,创建引人入胜和直观的UI;实用技巧和技术

简述 Jetpack Compose 是 Android 上的一种全新的 UI 工具箱,旨在简化 Android UI 开发流程,提高开发效率和应用性能,并且提供更直观、更灵活、更强大的 UI 定义方式。 Jetpack Compose 提供了一套新的声明式 UI 编程模型,采用 …

【Redis】多级缓存(nginx缓存、redis缓存及tomcat缓存)

【Redis】多级缓存 文章目录【Redis】多级缓存1. 传统缓存的问题2. 多级缓存方案2.1 JVM进程缓存2.1.1 本地进程缓存2.1.2 Caffeine2.2 Nginx缓存2.2.1 准备工作2.2.2 请求参数处理2.2.3 nginx发送http请求tomcat2.2.3.1 封装http查询函数2.2.3.2 使用http函数查询数据2.2.4 ng…

Huffman 编码

1.Huffman编码 1952年提出一种编码方法,该方法完全依据字符出现概率来构造异字头的平均长度最短的码字,有时称之为最佳编码,一般就叫做Huffman编码(有时也称为霍夫曼编码)。 2.Huffman树 树是一种重要的非线性数据结构,它是数据元…