MySQL 管理之道读书总结
最近读了《MySQL 管理之道》一书,做了以下总结,希望对大家有所帮助。在这里非常感谢作者的辛勤付出。
影响 MySQL 性能的因素:
影响 MySQL InnoDB 引擎性能的最主要因素就是磁盘 I/ O,目前磁盘都是机械方式运作的,主要体现在读写前寻找磁道的过程中。因此在单块磁盘遇到了I/ O瓶颈时,可以把磁盘升级为 RAID 或 SSD 固态硬盘来提升性能,
影响MySQL InnoDB 引擎性能的另一个因素就是内存,InnoDB 引擎在设计之初就是考虑用于大型、高负荷、高并发生产环境的,因此内存的大小直接反映了数据库的性能好坏。在 Buffer_ Pool 缓冲池中,涉及的参数为 innodb_ buffer_ pool_ size,它是 InnoDB 引擎中最重要的参数之一, 对 InnoDB 的性能有决定性的影响。默认的设置只有8MB,将其设置为60%~ 80%的内存。运维工作中常用的性能分析工具:
vmstat, sar, iostat, netstat,free, ps, top, mpstat.
推荐 Linux 服务器性能监控工具:dstat。collectl 以及淘宝开源监控项目Tsar等。在 MySQL5.6里,提供了快速预热Buffer_Pool缓冲池,只需要在 my.cnf 加入以下命令:
innodb_ buffer_ pool_ dump_ at_ shutdown = 1
解释:在关闭时把热数据 dump 到本地磁盘。
innodb_ buffer_ pool_ dump_ now = 1
解释:采用手工方式把热数据 dump 到本地磁盘。
innodb_ buffer_ pool_ load_ at_ startup = 1
解释:在启动时把热数据加载到内存。
innodb_ buffer_ pool_ load_ now = 1
解释:采用手工方式把热数据加载到内存。验证主从数据一致性工具:Maatkit 开源工具包。其中mk-table-checksum 是用来检测 master 和 slave 上的表结构和数据是否一致。mk-table-sync 是在主从数据不一致时,用来修复的。注意,这两个 perl 脚本在运行时都会锁表,表的大小取决于执行的快慢,不要再高峰期间运行,可选择凌晨。
软件部分性能优化主要涉及到数据库表设计(范式,字段类型,存储引擎),SQL语句与索引,配置文件参数,操作系统,文件系统, MysQL版本以及体系架构。
设计表结构可以满足第三范式。但三范式最大的问题在于查询时 通常需要 join 很多表,而这会导致查询效率很低。所以有时候基于性能考虑,我们需要有意违反三范式,适度地做冗余,以达到提高查询效率的目的。
字段类型的选取:主键强烈建议用 int 型。省空间,提高效率。根据需求选择最小整数类型。建表时时间类型优先选择 timestamp,具有自动更新时间的功能,而且只占用4字节。
在线更改表结构:pt-online-schema-change
MySQL 的锁具有一下几种形式:
表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高, 并发度最低。MyISAM引擎属于这种类型。
行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。InnoDB引擎属于这种类型。
页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定 粒度界于表锁和行锁之间,并发度一般。 NDB 属于这种类型。
InnoDB存储引擎是通过给索引上的索引项加锁来实现 的,这就意味着:只有通过索引条件检索数据, InnoDB 才会使用行级锁,否则, InnoDB 将使用表锁。两个事务都需要获得对方持有的排他锁才能继续完成事务,这种循环锁等待就是典型的死锁。发生死锁后,InnoDB一般都能自动检测到,它会让一个事务释放锁并回退,另一个事务则获得锁,继续完成事务。死锁是无法避免的,我们可以通过调整业务的逻辑来尽量减少死锁出现的概率。
尽量不要混合使用多种存储引擎,会带来复杂的问题。
MyISAM 和 InnoDB之间的主要区别有以下几点:
MyISAM是非事务安全型的,而InnoDB是事务安全型的,也就是ACID事务支持;
MyISAM锁是表级锁,锁开销最小,而InnoDB支持行级锁定,锁管理开销大,支持更好的并发写操作;·MyISAM支持全文索引,而InnoDB不支持全文索引,但在最新的5.6版本中已提供支持;
MyISAM相对简单,管理方便,因此在效率上要优于InnoDB,小型应用可以考虑使用MyISAM;
MyISAM表是保存成文件的形式,在跨平台的数据转移中使用MyISAM存储会省去不少的麻烦;
InnoDB表比MyISAM表更安全,可以在保证数据不会丢失的情况下,切换非事务表到事务表。事务的概念:ACID
事务的实现:MySQL在进行事务处理的时候使用的是日志先行的方式来保证事务可快速和持久运行的,也就是在写数据前,需要先写日志。当开始一个事务时,会记录该事务的一个LSN日志序列号;当执行事务时,会往InnoDB_Log_Buffer日志缓冲区里插入事务日志(redolog);当事务提交时,会将日志缓冲区里的事务日志刷入磁盘。这个动作是由innodb_flush_log_at_trx_commit这个参数控制的。
事务的隔离级别。
联合索引遵循最左侧原则。
SQL语句中包含or,不会使用索引,可以用union all 来替代。
like 如果是模糊匹配,则不能使用索引。如果匹配的字符串是以明确的字符串开头的话,是可以的。
去掉不必要的排序。
用where子句替换having子句,having子句用于一些集合函数的比较,例如count() 等。
字段使用函数,不能用到索引。
致命的无引号会导致全表扫描,不会用到索引。
主键的长度尽量不要太长;
固定长度的字符字段应使用char或nchar类型;
长度不固定的使用varchar或nvarchar。
对于可有可无的字段应尽量提供一个默认值。使用 on duplicate key update 解决主键冲突判断,冲突 update,不冲突 insert。
my.cnf配置文件调优。性能调试工具tuning-primer.sh
mydumper:一款高性能多线程的备份和恢复工具。
oneProxy分库分表。
Lepus 慢日志分析平台。
读/写分离的基本原理是:让master库处理事务增、删、改操作(INSERT、DELETE、UPDATE),而让slave库处理SELECT查询操作,replication数据库负责把数据变更同步到集群的slave库中。
MySQL 管理之道读书总结的更多相关文章
- MySQL管理之道:性能调优、高可用与监控内置脚本
MySQL管理之道:性能调优.高可用与监控内置脚本 随书附送脚本 keepalive配置文件和脚本开源工具pssh批量管理服务器(python) 下载地址 http://files.cnblogs.c ...
- MySQL管理之道:性能调优、高可用与监控》迷你书
MySQL管理之道:性能调优.高可用与监控>迷你书 MYSQL5.5.X主要改进 1.默认使用innodb存储引擎2.充分利用CPU多核处理能力3.提高刷写脏页数量和合并插入数量,改善I/O4. ...
- MySQL基础普及《MySQL管理之道:性能调优、高可用与监控》
最近工作的内容涉及MySQL运维内容,陆陆续续读了几本相关的书,其中一本是<MySQL管理之道:性能调优.高可用与监控>. 内容涵盖性能调优(包括sql优化等).备份.高可用,以及读写分离 ...
- MySQL管理之道,性能调优,高可用与监控(第二版)pdf下载
MySQL管理之道,性能调优,高可用与监控(第二版) 书中内容以实战为导向,所有内容均来自于笔者多年实践经验的总结和新知识的拓展,同时也针对运维人员.DBA等相关工作者会遇到的有代表性的疑难问题给出了 ...
- 使用mysql管理meta
第一部分 安装mysql 第二部分 使用mysql管理meta 安装mysql 安装 yum -y install mysql mysql-server yum方法安装需要使用网络:可以自动续传:对于 ...
- 15款最佳的MySQL管理工具和应用程序
工欲善其事,必先利其器.几乎每个开发人员都有最钟爱的 MySQL 管理工具,它帮助开发人员在许多方面支持包括 PostgreSQL,MySQL,SQLite,Redis,MongoDB 等在内的多种数 ...
- MYSQL管理之主从同步管理
原文地址:MYSQL管理之主从同步管理 作者:飞鸿无痕 MYSQL管理之主从同步管理 MYSQL主从同步架构是目前使用最多的数据库架构之一,尤其是负载比较大的网站,因此对于主从同步的管理也就显得非常重 ...
- mysql 管理工具
摘自: http://www.chinaz.com/free/2009/0306/68691.shtml MySQL是一个非常流行的小型关系型数据库管理系统,2008年1月16号被Sun公司收购.目前 ...
- Android内存管理之道
相信一步步走过来的Android从业者,每个人都会遇到OOM的情况.如何避免和防范OOM的出现,对于每一个程序员来说确实是一门必不可少的能力.今天我们就谈谈在Android平台下内存的管理之道,开始今 ...
随机推荐
- 百度未授权使用地图API
百度地图管理员的回复:这是KEY服务升级的问题, 给您造成的不便,非常抱歉.但我们昨日已修复,你可以再审核一番.若不可以,请提供一下您的系统ak,邮箱或qq发送至(wangwenhai@baidu.c ...
- Android环境的搭建及Android Studio的安装
菜鸟初来报到,写了一篇关于Android环境搭建和Android Studio安装的内容(写好很久了,一直没发).仅供想开发Android,却又不知如何搭建环境的小白们参考,高手们就请绕行吧.在此献丑 ...
- P1593 因子和
P1593 因子和新算法:#define ni 逆元先质因数分解,(1+p1^1+p1^2...p1^x)*(1+p2^1+p2^2...p2^x)然后套等比数列公式就可以了. #include< ...
- js异步刷新局部页面
真不想说博客园的Markdown编辑器,我发表到我的个人博客上多好看的一篇文章,发到博客园上格式就成这个鸟样了,哎,不发现到博客首页了,就个人存个档吧 最近在做一个异步刷新页面中的局部,这样做可以防出 ...
- Nutch源码阅读进程4
前面依次看了nutch的准备工作inject和generate部分,抓取的fetch部分的代码,趁热打铁,我们下面来一睹parse即页面解析部分的代码,这块代码主要是集中在ParseSegment类里 ...
- Web大前端面试题-Day11
86.如何获得高效的数据库逻辑结构? 从关系数据库的表中 删除冗余信息的过程 称为数据规范化, 是得到高效的关系型数据库表的逻辑结构 最好和最容易的方法. 规范化数据时应执行以下操作: 1.将数据库的 ...
- 潭州课堂25班:Ph201805201 并发(进程,线程) 第十一课 (课堂笔记)
线程,进程,是实现并发的方法, 并行: 在同一时刻,同时运行多个任务,CPU 的数量大于等于任务数量, 并发: 在同一时间间隔内, 同时处理多个任务, 并行是并发. 进程:表示一个正在执行的程序, 操 ...
- Putty的用法
大致内容罗列如下: · 最简单的使用,登录 SSH主机 · 中文乱码的处理 · PuTTY常用配置的说明 · 复制.粘贴 · 保存 ...
- memcached 一致性哈希算法
本文转载自:http://blog.csdn.net/kongqz/article/details/6695417 一.概述 1.我们的memcache客户端使用了一致性hash算法ketama进行数 ...
- Android Developers:传感器概述
大 多数Android设备有内置的传感器,来测量运动,方向和各种环境条件.这些传感器能提供高精度和准确度的原始数据,如果你想监控设备三维运动或者位 置,或者你想监控设备周围的环境变化,是非常有用的.例 ...