MySQL优化常用
一.mysql的配置都是小写的,使用下划线_或破折号-分割单词,两者是一样的
二.在配置文件中可以用1m,1g等单位,但是用set命令,不能使用单位,默认单位是字节
三.特殊例子
a.query_cache_size变量是全局性的
b.sort_buffer_size变量有全局性默认值,但是可以在回话中改变
c.join_buffer_size有全局性的默认值,可以在会话中设置,但是联接了几个表的查询可能会每个联接都分配一个联接缓冲区,所以每个查询都可能有几个联接缓冲区
四.注意事项
a.key_buffer_size
设置这个变量给键缓存区分配指定大小的空间.但是操作系统只是在实际用到的这些空间的时候才会分配.可以创建多个键缓存.
b.table_cache_size
设置这个变量,不会立即生效,要等到下个线程打开表的时候才会生效.当它生效的时候,mysql会检查变量的值.如果设置的值大于缓存表的数量,线程就把表插入到缓存,否则,就从缓存中删除不用的表,再插入.
c.thread_cache_size(线程缓存的数量)
这个设置不会立即生效,生效到线程关闭的时候.如果有空间存储线程,就缓存.如果不是,直接结束掉线程
d.query_cache_size
在服务启动的时候,mysql会一次性分配所定义的变量内存.如果更新了变量,mysql会删除掉当前缓存的.即便值设置为当前值.
e.read_buffer_size
当查询不断的扫描一个表,mysql会分配一个缓存区.这个缓存区就是read_buffer_size所定义的大小.mysql只有在查询用到的时候,才会分配,而且是一次性分配该变量指定的大小.
f.read_rnd_buffer_size(该变量更精确的名字应该是max_read_rnd_buffer_size)
加速排序操作后的读数据,提高读分类行的速度。如果正对远远大于可用内存的表执行GROUP BY或ORDER BY操作,应增加read_rnd_buffer_size的值.
需要用到时才会分配,并且只分配需要大小的内存.
g.sort_buffer_size(每个线程排序所需要的缓存)
只要发生排序,就会分配,并一次性分配指定大小.不管是否需要这么多
五.myisam调优
1.mysql安装后,会有my-huge.cnf,my-larege.cnf等配置文件,这些配置文件通常适用于myisam
2.key_buffer_size,应该占到保留内存的25%到50%,对于mysql5.0,该变量最大上限是4GB
3.可以创建多个缓存区,这样就可以一次在内存中保存超过4GB以上的索引,为了创建名为key_buffer_1和key_buffer_2,大小都为1GB的缓存区,可以在配置文件中加入
key_buffer_1.key_buffer_size = 1G
key_buffer_2.key_buffer_size = 1G
可以使用CREATE INDEX命令把表映射到缓存
通过下面命令把表t1和t2的索引保存到key_buffer_1上
mysql>CREATE INDEX t1,t2 IN key_buffer_1;
还可以使用LOAD INDEX预加载表索引到缓存中:
mysql>LOAD INDEX INTO CACHE t1,t2;
4.缓存命中率
100 - ( (Key_reads * 100) / Key_read_requests )
下面的命令以10s幅度递增,计算了总的未命中次数
#mysqladmin extended-status -r -i 10 | grep Key_reads
5.没有必要让key_buffer_size大于索引数据大小
#du -sch `find /path/to/mysql/data/directory -name "*.MYI"
通过以上命令,找出存储索引文件的大小
6.myisam数据块大小
myisam_block_size该值确定了该项大小,这与系统页面大小相关.x86架构中,系统页面大小为4k,该值与系统页面大小相同可避免写入等待
六.InnoDB调优
1.InnoDB严重依赖于缓冲池.可以将80%的物理内存分配给它.
innodb_buffer_pool_size确定该大小
2.innodb_max_dirty_pages_pct该值确定了保留在缓存池中被修改的页面的数量.但达到90%的时候,开始数据冲刷到磁盘.该值设置的小,可以更好的吸收写入尖峰.
3.如果使用innodb_file_per_table选项,那么对innodb任何时候打开的.ibd文件还有另外一个限制.它受innodb_open_files的控制.如果可以的话,尽量将innodb_open_files设置的足够大.这样服务器就可以同时保留所有打开的.idb文件
MySQL优化常用的更多相关文章
- mysql 优化常用语句
show status;//查询mysql各种状态: show variables like 'long_query_time';//慢查询的限定时间 set long_query_time=1;// ...
- 项目中常用的19条MySQL优化
声明一下:下面的优化方案都是基于 " Mysql-索引-BTree类型 " 的 一.EXPLAIN 做MySQL优化,我们要善用 EXPLAIN 查看SQL执行计划. 下面来个简单 ...
- MySQL优化(2)--------常用优化
前言 之前已经简单介绍了MySQL的优化步骤,那么接下来自然而是就是常用的SQL优化,比如inseer.group by等常用SQL的优化,会涉及SQL语句内部细节(这正是我缺乏的).最后希望自己能记 ...
- 项目中常用的MySQL 优化
本文我们来谈谈项目中常用的MySQL优化方法,共19条,具体如下: 一.EXPLAIN 做MySQL优化,我们要善用EXPLAIN查看SQL执行计划. 下面来个简单的示例,标注(1.2.3.4.5)我 ...
- SQL学习笔记之项目中常用的19条MySQL优化
在写文章之前,首先感谢 飞友科技 陆老师提供的文档.. 声明一下:下面的优化方案都是基于 “ Mysql-索引-BTree类型 ” 的 0x00 EXPLAIN 做MySQL优化,我们要善用 EXPL ...
- 项目中常用的MySQL优化方法--壹拾玖条
1.EXPLAIN 做MySQL优化,我们要善用EXPLAIN查看SQL执行计划. 下面来个简单的示例,标注(1.2.3.4.5)我们要重点关注的数据: type列,连接类型.一个好的SQL语句至少要 ...
- 19条常用的MySQL优化方法(转)
本文我们来谈谈项目中常用的MySQL优化方法,共19条,具体如下:1.EXPLAIN命令做MySQL优化,我们要善用EXPLAIN查看SQL执行计划.下面来个简单的示例,标注(1.2.3.4.5)我们 ...
- 项目中常用的19条MySQL优化技巧
原文:https://segmentfault.com/a/1190000012155267 声明一下:下面的优化方案都是基于 “ Mysql-索引-BTree类型 ” 的 一.EXPLAIN 做My ...
- 常用的 19 条 MySQL 优化
一.EXPLAIN 做MySQL优化,我们要善用 EXPLAIN 查看SQL执行计划. 下面来个简单的示例,标注(1,2,3,4,5)我们要重点关注的数据 type列,连接类型.一个好的sql语句至少 ...
随机推荐
- DbHelper-SQL数据库访问助手
using System; using System.Data; using System.Data.SqlClient; namespace Whir.Software.Framework.Ulti ...
- chrome扩展程序开发之在目标页面运行自己的JS
大家都知道JS是运行在客户端的,所以,如果我们自己写一个浏览器的话,是一定可以往下载下来的网页源代码中加入js的.可惜我们没有这个能力.不过幸运的是,chrome的扩展程序可以帮我们做到这件事. 本文 ...
- js:语言精髓笔记5----语言分类
计算模型:源于对计算过程的不同认识: 1.基于不同计算模型一般分为://教科书的一般分类 命令式语言: 函数式语言: 逻辑式语言: 面向对象程序设计语言: 2.基于程序本质分类: //编程的经典法则 ...
- 如何找到所有HTML Select 标签的选中项?
$(‘[name=NameofSelectedTag]:selected’);
- asp.net 未能写入输出文件--“拒绝访问”的解决办法
概述 将网部署在IIS 7 上,访问本地磁盘路径的时候,提示"**文件拒绝访问". 解决办法 将需要访问的文件夹赋于IIS_IUSRS完全控制的权限即可,不用添加NET ...
- SPOJ371 Boxes(最小费用最大流)
把球当作水. #include<cstdio> #include<cstring> #include<queue> #include<algorithm> ...
- 浅谈MySQL索引背后的数据结构及算法
摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持也各不相同,因此MySQL数据库支持多种索引类型,如BT ...
- ios ASIHttpLib 同步请求和异步请求
1.同步请求可以从因特网请求数据,一旦发送同步请求,程序将停止用户交互,直至服务器返回数据完成,才可以进行下一步操作, 2.异步请求不会阻塞主线程,而会建立一个新的线程来操作,用户发出异步请求后,依然 ...
- COJ0700 数学(一)
试题描述 现在有一大堆数,请你对这些数进行检验. 输入 第一行:CAS,代表数据组数(不大于500000),以下CAS行,每行一个数字,保证在64位长整形范围内,并且没有负数.你需要对于每个数字检验是 ...
- FreeMarker教程
一.什么是模板引擎,为什么要用模板引擎 在B/S程式设计中,常常有美工和程序员二个角色,他们具有不同专业技能:美工专注于表现——创建页面.风格.布局.效果等等可视元素:而程序员则忙于创建程式的商业流程 ...