MySQL优化

Posted 琳淼

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL优化相关的知识,希望对你有一定的参考价值。

mysql最大连接数设置:
在配置文件的[mysqld]下面
max_connections = 1000 #mysql的最大连接数,默认如果不写的话是100个
wait_timeout = 10 超时时间
命令:
show status like ‘%Threads_connected%‘;查看当前连接数
show processlist;
1、mysql缓存
queryCache:
1、数据有变化的时候,缓存就失效了??
2、select语句必须一模一样才能走缓存,只要有一点不一样就不会走
3、任何一个包含不确定的函数(比如now(),current_date())的查询不会被缓存。
开启qcache:
在配置文件的[mysqld]下面
query_cache_type = on#开启缓存
query_cache_size = 10M #总大小
query_cache_limit = 1M #select查询结果超过设置值,就不会被缓存
SHOW VARIABLES LIKE ‘%query_cache%‘;查看queryCache状态
开启profile:
set @@profiling=1;#设置profile开启
select @@profiling;#查看profile是否被开启
show profiles;#查看所有的profile
show profile for query n;查看指定的sql语句
queryCache使用状态:
Qcache_free_memory Query Cache 中目前剩余的内存大小
Qcache_hits 缓存命中次数
Qcache_inserts 多少次未命中然后插入
Query Cache 命中率= Qcache_hits / ( Qcache_hits + Qcache_inserts );
Qcache_free_blocks Query Cache中目前还有多少剩余的blocks。如果该值显示较大,则说明Query Cache 中的内存碎片较多了,可能需要寻找合适的机会进行整理。
如果这个值非常大,可以使用FLUSH QUERY CACHE;语句来清理查询缓存碎片以提高内存使用性能。该语句不从缓存中移出任何查询。
2、innodb 存储引擎
支持外键、支持事物,行级锁,innodb
MyISAM
MyISAM表不支持事务
MyISAM表不支持外键(Foreign Key)。
Innodb是行级锁,myisam是表锁
开启innodb_buffer_pool
在配置文件的[mysqld]下面
innodb_buffer_pool_size=20M #设置bufferpool大小
innodb_buffer_pool_dump_now=on#默认为关闭OFF。如果开启该参数,停止MySQL服务时,InnoDB将InnoDB缓冲池中的热数据保存到本地硬盘。
innodb_buffer_pool_load_at_startup = off#默认为关闭OFF。如果开启该参数,停止MySQL服务时,InnoDB将InnoDB缓冲池中的热数据保存到本地硬盘。
SHOW VARIABLES LIKE ‘%innodb_buffer_pool%‘;
#查看bp的设置
SHOW STATUS LIKE ‘%Innodb_buffer_pool%‘;
查询Innodb_buffer_pool当前使用情况:
innodb_buffer_pool_bytes_data 已经使用了多少
innodb_buffer_pool_read_requests 总共查询bp的次数
innodb_buffer_pool_reads 从物理磁盘中获取到数据的次数
读写分离:
主:只负责写数据
从:只负责读数据
偶发性延时的话:控制写入速度
频发性延时:拆分数据库实现多点写入
把数据分散到不同的数据库上
explain sql;
desc sql;
type这一列:
all<index<range<ref<eq_ref<const,system<null
效率最差到最好

 


2、mysql sql语句的生命周期
3、索引
普通索引:所有列都可以添加索引
create index ‘my_index‘ on bkl(name);
alter table blk add index my_index2 (sex);
#上面这两种方式都是添加普通索引

alter table blk add index my_index3 (sex,name);#添加组合索引


alter table blk add unique index my_index4 (phone);#添加唯一索引
create unique index ‘my_index5‘ on bkl(phone);
#添加唯一索引

添加主键索引:
alter table blk modify id int primary key;
删除索引:
alter table blk drop index my_index2;

唯一索引:unique
主键索引:primary ky
组合索引、多列索引:


4、慢查询
SHOW VARIABLES LIKE ‘%query%‘;#查询慢查询日志是否开启
set global slow_query_log=on;#开启慢查询日志
set global long_query_time=1;#设置记录查询超过多长时间的sql
set global slow_query_log_file=‘/opt/data/slow_query.log‘;#设置mysql慢查询日志路径,此路径需要有写权限
mysqldumpslow命令参数如下:
-s,是表示按照何种方式排序,c、t、l、r分别是按照记录次数、时间、查询时间、返回的记录数来排序,ac、at、al、ar,表示相应的倒叙;
-t,是top n的意思,即为返回前面多少条的数据;
-g,后边可以写一个正则匹配模式,大小写不敏感的
例子:#比如说要按照sql执行时间最长的前20条sql
mysqldumpslow -s t -t 20 -g ‘select‘ /opt/data/slowquery_2016050921.log
通过慢查询日志,就可以找到执行效率不高的sql

 

5、sql语句怎么去优化

6、锁
如果修改的数据的时候条件是索引列就是行级锁,
条件不是索引列的时候才是表级锁。
show processlist;
show engine innodb status;#一般日志里有dblock、lock等字样
7、事务


























































































以上是关于MySQL优化的主要内容,如果未能解决你的问题,请参考以下文章

mysql 优化包括哪些内容?

Mysql的性能优化

Mysql的性能优化

mysql 子查询 优化

MySQL Optimization

MySQL优化MySQL 高并发配置优化基础知识