MySQL 优化--持续整理
一、innodb体系结构优化:
1、IO优化
IO能力不足时
innodb_io_capacity 应该降低
innodb_max_dirty_pages_pct 应该降低
innodb_max_dirty_pages_pct_lwm 如果设置了应该考虑降低
innodb_read_io_threads
innodb_write_io_threads
2、Purge Thread
innodb_purge_threads 设置purge线程个数,用于undo页回收
innodb_purge_batch_size 设置Purge undo 的页数量,默认300
innodb_max_purge_lag
控制undo log history list的长度,0表示不对history list 做任何限制。当大于0时,就会
延缓DML的操作。延缓对象是行。
innodb_max_purge_lag_delay 用来控制delay的最大毫秒数。
3、内存池buffer pool
innodb_buffer_pool_size 内存池大小设置
innodb_buffer_pool_instances 多内存池设置
4、LRU List、Free List和Flush List
innodb_old_blocks_pct 设置新页放到LRU List位置 mid位置
innodb_old_blocks_time mid位置后的页,要多久能被加入到LRU列表的热端
5、Redo Log
innodb_log_buffer_size redo buffer 的大小
三种情况刷新日志缓冲
1)master thread 每秒刷
2)事务提交时刷
3)日志空间小于1/2刷
6、Page Cleaner
innodb_io_capacity
合并插入缓冲时,合并的数量为innodb_io_capacity的5%
刷新脏页时,刷新的数量为innodb_io_capacity
innodb_max_dirty_pages_pct
innodb_max_dirty_pages_pct_lwm
innodb_adaptive_flushing 自适应刷新
InnoDB刷新脏页的规则是在如下三种情况下才会把InnoDB_Buffer_Pool的脏页刷入磁盘:
当超过innodb_max_dirty_pages_pct设定的值时。
重做日志ib_logfile文件写满了以后。
机器空闲的时候。
当写操作很频繁的时候,重做日志ib_logfile切换的次数就会很频繁,只要有一个写满了,就会将脏页大批量地刷入磁盘,而这会对系统的整体性能造成不小的影响。为了避免过大的磁盘I/O,innodb_adaptive_flushing会自适应刷新,它使用了一个全新的算法,以便根据重做日志ib_logfile生成的速度和刷新频率来将脏页刷入磁盘,这样重做日志ib_logfile还没有写满时,也可以刷新一定的量。
7、insert buffer(change buffer)
innodb_change_buffering changebuffer 支持的类型 insert、update、delete等
innodb_change_buffer_max_size insert buffer 的大小,占innodb_buffer_pool的百分比(默认25%,最大50%)
8、double write 两次写
show status like 'innodb_dblwr%';
如果Innodb_dblwr_pages_written:Innodb_dblwr_writes远小于64:1说明系统压力很小
9、自适应哈希索引
10、异步IO(AIO)
innodb_use_native_aio 应打开异步IO
用户发布一个IO请求后,可以立即再发出另一个IO请求,当全部IO请求发送完毕,等待所有
IO操作完成。
AIO还可以进行IO Merge 操作。
11、刷新临近页
innodb_flush_neighbors 根据系统IO能力调整,如果是IO处理能力和高,需要关闭
12、
二、索引优化:
1、打开Multi-Range Read功能(5.6新功能)
它的作用针对基于辅助/第二索引的查询,减少随机IO,并且将随机IO转化为顺序IO,提高查询效率。
1)打开
set optimizer_switch='mrr=on mrr_cost_based=on'; #mrr_cost_based表示开启mrr后,优化器是否根据cost来决定是否使用mrr
set oprimizer_switch='mrr=off';
2)MRR内存设置
对于MRR,参数read_rnd_buffer_size用来控制键值缓冲区的大小。
2、打开Index Condition Pushdown功能(5.6新功能)
set optimizer_switch = 'index_condition_pushdown=off';
set optimizer_switch = 'index_condition_pushdown=on';
2、Index Condition Pushdown(ICP)


sync_binlog
sync_binlog=1,表示提交一次写一次binlog。
当一个事务发出commit动作之前,由于sync_binlog=1,因此会将二进制日志立即写入磁盘。
如果这时已经写入了二进制日志,但是提交没有发生,并且此事发生了宕机,那么在Mysql
数据库下次启动时,由于commit操作并没有发生,这个事务会被回滚掉。但是,二进制日志
已经记录了该事务信息,不能被回滚。这个问题由参数innodb_support_xa 来解决,
innodb_support_xa= 1 保证二进制日志和InnoDB 存储引擎数据文件同步。
binlog-do-db/binlog-ignore-db
log-slave-update
binlog_format
expire_logs_days
MySQL 优化--持续整理的更多相关文章
- 关于MYSQL优化(持续更新)
*利用MYSQL数据缓存提高效率,注意事项: 1.应用环境:不经常改变的表及对此表相同的查询 2.不适用于服务器端编写的语句 3.根据数据使用频率,合理分解表 4.合理使用默认条件,提高命中率 5.统 ...
- MYSQL优化之碎片整理
MYSQL优化之碎片整理 在MySQL中,我们经常会使用VARCHAR.TEXT.BLOB等可变长度的文本数据类型.不过,当我们使用这些数据类型之后,我们就不得不做一些额外的工作--MySQL数据 ...
- MySQL优化整理
一.SQL优化 1.show status查看各种sql的执行频率 SHOW STATUS 可以根据需要显示 session 级别的统计结果和 global级别的统计结果. 显示当前sessi ...
- 整理的网上的MySQL优化文章总结
MySQL优化 Linux优化 IO优化 调整Linux默认的IO调度算法. IO调度器的总体目标是希望让磁头能够总是往一个方向移动,移动到底了再往反方向走,这恰恰就是现实生活中的电梯模型,所以IO调 ...
- [转] MySql 优化 大数据优化
一.我们可以且应该优化什么? 硬件 操作系统/软件库 SQL服务器(设置和查询) 应用编程接口(API) 应用程序 ------------------------------------------ ...
- mysql优化案例
MySQL优化案例 Mysql5.1大表分区效率测试 Mysql5.1大表分区效率测试MySQL | add at 2009-03-27 12:29:31 by PConline | view:60, ...
- MySQL优化聊两句
原文地址:http://www.cnblogs.com/verrion/p/mysql_optimised.html MySQL优化聊两句 MySQL不多介绍,今天聊两句该如何优化以及从哪些方面入手, ...
- mysql 优化
1.存储过程造数据 CREATE DEFINER=`root`@`localhost` PROCEDURE `generate_test_data`(`n` int) begin declare i ...
- MySQL优化概述
一. MySQL优化要点 MySQL优化是一门复杂的综合性技术,主要包括: 1 表的设计合理化(符合 3NF,必要时允许数据冗余) 2.1 SQL语句优化(以查询为主) 2.2 适当添加索引(主键索引 ...
随机推荐
- 计算机网络自顶向下方法第3章-传输层 (Transport Layer).2
3.5 面向连接的运输: TCP 3.5.1 TCP连接 TCP是因特网运输层的面向连接的可靠的运输协议. TCP连接提供全双工服务(full-duplex service). TCP连接是点对点的连 ...
- Python——raise引发异常
程序出现错误,会自动引发异常,Python也允许使用raise语句自行引发异常. 一.使用raise引发异常 单独一个raise引发异常,默认引发RuntimeError异常,例: try: prin ...
- c++实现双端队列
在使用c++容器的时候其底层如何实现 例如 vector 容器 :是一个内存可以二倍扩容的向量容器,使用方便但是对内存要求严格,弊端明显 list 容器 : 双向循环链表 deq ...
- 最佳thread数量
cpu 密集性task,过多的线程反而降低了处理效率,最佳的做法就是保持和cpu core数量大致相同的线程数量: threads = number of CPUs + 1 io密集型,因为会有cpu ...
- interface Part4(接口中的多态)
使用接口实现多态 需要满足以下两个条件. 定义接口并使用类实现了接口中的成员. 创建接口的实例指向不同的实现类对象. 假设接口名称为 ITest,分别定义两个实现类来实现接口的成员,示例代码如下. i ...
- css中哪些属性会脱离文档流
一共有三个属性会使元素脱离文档流: (1)浮动 (2)绝对定位 (3)固定定位 元素脱离文档流会导致父元素高度塌陷,要修复高度塌陷问题,可以将子元素与父元素放在同一个BFC中
- c# dynamic实现动态实体,不用定义实体就能序列化为标准json
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.D ...
- C++ 基础知识汇总 持续更新
摘录一些C++面试常考问题,写一些自己的理解,花了挺长时间的,作图是真的累,欢迎来摘果子. static关键字 用于声明静态对象: 静态函数只在本文件可见.(默认是extern的) 全局静态对象:全局 ...
- Session机制详解及分布式中Session共享解决方案
一.为什么要产生Session http协议本身是无状态的,客户端只需要向服务器请求下载内容,客户端和服务器都不记录彼此的历史信息,每一次请求都是独立的. 为什么是无状态的呢?因为浏览器与服务器是使用 ...
- IDEA 中常用快捷键
1.搜索文件(整个项目) ctrl+shift+n 2.最近打开文件 ctrl+e 3.实现接口中方法 ctrl+i 4.跳到上一行 ctrl+alt+enter 5.删除当前行 ctrl+y 6.重 ...