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平台下内存的管理之道,开始今 ...
随机推荐
- 【BZOJ】3123: [Sdoi2013]森林
题解 ------------------ 我莫不是一个智障吧 我把testdata的编号 当成数据组数读进来 我简直有毒 以为哪里写错了自闭了好久 实际上这题很简单,只要愉悦地开个启发式合并,然后每 ...
- python全栈开发day12-函数的有用信息、带参数的装饰器、多个装饰器装饰一个函数、global和nonlocal的进一步解析和总结
1.上周回顾 1).函数名的应用 直接打印函数名,是函数的地址 变量 函数的参数 函数的返回值 可以当容器类数据类型的元素 2).闭包 内层函数对外层函数的非全局变量的引用,就是闭包. 并返回内部函数 ...
- java07接口与继承动手动脑
1.源代码: package Work; class A{ public A(){ System.out.println("Class A."); } public A(Strin ...
- 093实战 Nginx日志切割,以及脚本上传nginx的切割日志
一:日志切割步骤 命令都在root下进行 1.创建目录 mkdir -p /etc/opt/modules/bin ## 创建文件夹 2.上传cut 3.观察目录 4.修改的cut文件 5.检测 需要 ...
- 如何查看Ubuntu版本,以及Linux内核版本??
查看Ubuntu版本: 方法一: cat /etc/issue 方法二: sudo lsb_release -a 查看内核版本: uname -r
- Ubuntu 之 atom 安装以及 常用配置
安装方式如下: 打开终端,使用以下命令安装: sudo add-apt-repository ppa:webupd8team/atom sudo apt-get update sudo apt-get ...
- pandas学习(创建多层索引、数据重塑与轴向旋转)
pandas学习(创建多层索引.数据重塑与轴向旋转) 目录 创建多层索引 数据重塑与轴向旋转 创建多层索引 隐式构造 Series 最常见的方法是给DataFrame构造函数的index参数传递两个或 ...
- Luogu
dalao们的博客a http://hzwer.com //Orz %%% https://oi-wiki.org //Orz https://www.cnblogs.com/-guz/p/9 ...
- 潭州课堂25班:Ph201805201 第四课:Linux的命令以及VIM的使用 (课堂笔记)
Linux的常用命令 引入 1:如果我们要在Linux里面实现一些比如查看文件和文件夹.新建文件夹之类的操作,应该是通过什么来实现 2:讲解Linux目录树 3:讲解Linux只区分文件名,Linux ...
- 为何IT开发人员如此辛苦?
一个本来挺简单的功能,硬是让PM(产品经理)设计的非常复杂,各种逻辑切换.这样不但用户体验不好,还容易出各种bug.为了让用户学会使用产品,用了各种引导图,什么手势引导,按钮点击引导,提示弹窗都用上了 ...