前言
数字化转型已经开始从IT时代进入DT时代。面对大量的数据和业务,已经有许多的公司意识到了数据价值的重要性,如何管理和利用好数据变得越来越重要。数据库系统在现在便成为了核心,其高可用性和容灾能力对整个业务系统的连续性和数据完整性起着至关重要的作用,已经成为企业正常运营的关键所在。作为最流行的开源数据库软件之一,MySQL数据库软件可以说知名度不断在攀升。以MySQL为主的开源技术生态正变得越来越流行,随着不断地发展,现在已经成为当下互联网领域的主流数据库。有着不容撼动的地位。像现在Facebook、Twitter、谷歌、腾讯、阿里等都在大量使用MySQL数据库存储海量数据。
我认为如果把mysql比喻成数据库界的一头猛虎,那么性能优化和高可用架构设计实践就是一双翅膀.尤其是在性能优化与高可用架构两方面,很多从业多年的dba限于固定体系,往往盲人摸象,难窥全局.而性能优化和高可用又是一对存在根本矛盾的特性.可以说,掌握了这两项技术的平衡,就掌握了mysql的绝大部分内容,也就把握了数据库核心技术的最主流脉络.
尤其是现在正处于“金九”这个跳槽加薪的热季,掌握一项关键技术就成为了核心所在。因此,今天小编我为大家分享一份由清华毕业的顶级架构师编写的《MySQL性能优化学习手册》主要详解MySQL高可用和性能优化技术,细致梳理思路,同时与真实生产案例相结合,通过原理阐述到实战部署,帮助大家快速将所学知识点灵活运用,实现技术上的突破!
MySQL性能优化学习手册目录总览由目录可见,这份文档的内容所涵盖知识点非常地全面。全篇一共分为13章,由原理阐述到实战部署详细解析。由于内容太多无法全部展示出来。如果你对这份资料感兴趣,还请点赞转发之后,主页私信“”免费领取完整版资料
第1章MySQL架构介绍
MySQL是20世纪90年代出来的数据库,整个架构上吸取了其他数据库的一些优良特性,也去除了不好的地方,整个架构比较稳定、比较简洁。MySQL的架构可以多种不同的场景中应用
第2章InnoDB存储引擎体系结构
从MySQL5.5版本开始,InnoDB是默认的表存储引擎,特点是支持事务、支持数据行锁、支持多版本并发MVCC、支持外键.
第3章MySQL事务和锁
事务可以只包含一条SQL语句,也可以包含多条复杂的SQL语句。事务中的所有SQL语句被当作一个操作单元,换句话说,事务中的SQL语句要么都执行成功,要么全部执行失败。事务内的SQL语句被当作一个整体进行操作。
锁在计算机中是协调多个进程或线程并发访问某一资源的一种机制。在数据库中,除了传统的计算资源(CPU、RAM、I/O等)争用之外,数据也是一种供许多用户共享访问的资源。数据库在进行并发访问的时候会自动对相应的对象进行加锁,以保证数据并发访问的一致性。InnoDB存储引擎既支持行级锁,也支持表级锁,但默认情况下采用行级锁
第4章SQL语句性能优化
说起SQL语句性能优化,相信所有人都了解一些简单的技巧:不使用SELECT*、不使用NULL字段、合理地使用索引、为字段选择恰当的数据类型等。你是否真的理解这些优化技巧?是否理解其背后的工作原理?本章从理论和实战角度出发,讲解这些优化建议背后的原理。
第5章MySQL服务器全面优化
绝大多数使用Linux操作系统的大中型互联网网站都在使用MySQL。作为后端的数据库服务,所以如何优化MySQL服务器是我们要研究的。
第6章MySQL性能监控
MySQL被越来越多的企业接受。随着企业发展,MySQL存储数据日益膨胀,性能分析、监控预警显得非常重要。在某些场景下,通常会部署一套MySQL监控/图形工具,然后根据MySQL监控面板提供的信息来执行进一步的调优
第7章MySQL主从复制详解
MySQL的主从复制功能是构建基于MySQL数据库的高可用、高性能的应用程序基础,既能用于分担主数据库的读负载,也为高可用HA等工作提供了更多的支持。
第8章PXC高可用解决方案
Percona公司的PerconaXtraDBCluster(简称PXC)是基于Galera协议的MySQL高可用性集群架构,集成了PerconaServer和PerconaXtraBackup,同时采用了CodershipGalera库。PerconaXtradbCluster在原MySQL代码上通过Galera包将不同的MySQL实例连接起来,实现了multi-master的集群架构。它可以实现多个MySQL节点间的数据同步复制以及读写,不但可以保障数据库的服务高可用,而且保证整个集群所有数据的强一致性,满足CAP理论中的一致性(Consistency)和可用性
第9章基于MHA实现的MySQL自动故障转移集群
MHA(MasterHighAvaliability)是由日本的一位工程师采用Perl语言编写的一个脚本管理工具,是一款开源的MySQL高可用解决方案软件,能在MySQL主从复制的基础上实现自动化主服务器故障转移,目前在MySQL高可用方面是一个相对成熟的解决方案。在MySQL故障切换过程中,MHA能做到在30秒之内自动完成数据库的故障切换操作,并且在进行故障切换的过程中能在最大程度上保证数据的一致性,以达到真正意义上的高可用
第10章MySQLGroupReplication
MySQLGroupReplication是MySQL官方于年12月推出的一个全新的高可用的解决方案。
MGR被认为是继OracleDatabaseRAC之后又一个“真正”的集群,也是MySQL官方基于组复制概念并充分参考MariaDBGaleraCluster和PerconaXtraDBCluster结合而来的新的高可用集群架构。
第11章Keepalived+双主复制的高可用架构
双主复制配合Keepalived这种MySQL高可用架构设计也是基于MySQL的主从复制原理,而Keepalived使用VIP,并利用Keepalived自带的服务监控功能和自定义脚本来实现master主服务器故障自动切换。这套MySQL双主复制+Keepalived架构其实可以适用于各种业务,是一种简单、便捷的高可用方案。
第12章数据库分库分表与中间件介绍
大型网站用户数和数据库规模急剧上升,关系型数据库常见的性能瓶颈主要体现在两点:一是大量的并发读写操作,导致单库出现负载压力过大;二是单表存储数据量过大,导致查询效率低下。这时常见的做法便是对数据库实施分库分表即Sharding改造来应对海量数据和高并发对数据库的冲击,与此同时,支持分库分表并且对业务开发透明的数据库中间件也大行其道。
第13章Mycat中间件详解
由于真正的数据库需要存储引擎,而Mycat并没有存储引擎,因此它并不是完全意义上的分布式数据库系统,可以更贴切地说成是数据库的中间件,就是介于数据库与应用之间进行数据处理与交互的中间服务。传统的访问数据库是直接连接数据库,创建数据库实例,根据需求对数据库中的数据进行增删查改。但是,当我们使用Mycat后,其实直接连接的是Mycat,通过Mycat对真正的数据库进行操作,在Mycat上我们可以做一些分表分库等操作,达到我们对数据库的可扩展要求。
好了,本文到这里就结束了。由于这份资料内容实在太多,所以在这用截图的方式只展示了部分内容,看到这里,对这份资料感兴趣的朋友请页私信小编回复“”即可领取。