mysq优化】的更多相关文章

Mysql配置参数: thread_pool:如果支持的话,使用线程池 innodb_buffer_pool_size:物理内存50%-70%最高80%独立实例,多实例:60% innodb_flush_log_at_trx_commit & sync_binlog:数据的一致性和丢失风险的评估,不允许丢失等设置为1,允许数据丢失风险commit为2,sysncs设置大点,如果不考虑丢失都设置为0 innodb_file_per_table:启动独立表空间模式.有很多的优势, innodb_da…
MySQL调优可以从几个方面来做:1. 架构层:做从库,实现读写分离: 2.系统层次:增加内存:给磁盘做raid0或者raid5以增加磁盘的读写速度:可以重新挂载磁盘,并加上noatime参数,这样可以减少磁盘的i/o; 3. MySQL本身调优:(1) 如果未配置主从同步,可以把bin-log功能关闭,减少磁盘i/o(2) 在my.cnf中加上skip-name-resolve,这样可以避免由于解析主机名延迟造成mysql执行慢(3) 调整几个关键的buffer和cache.调整的依据,主要根…
查询性能优化 1. 为什么查询速度会慢? 1). 如果把查询看作是一个任务,那么它由一系列子任务组成,每个子任务都会消耗一定的时间.如果要优化查询,实际上要优化其子任务,要么消除其中一些子任务,要么减少子任务的执行次数,要么让子任务运行的更快. 2). 通常来说,查询的生命周期大致可以按照顺序来看:从客户端,到服务器端,然后在服务器上进行解析,生成执行计划,执行,并返回结果给客户端.其中"执行"可以认为是整个生命周期中最重要的阶段,这其中包括 大量为了检索数据到存储引擎的调用以及调用后…
MYSQL支持的索引类型 BTREE索引 特点: 通过引用以B+权的结构存储数据 能够加快数据的查询速度 更适合进行范围查找 应用: 全值匹配的查询 = 匹配最左前缀的查询 匹配列前缀查询 LIKE 'XX%' 匹配范围值的查询 精确匹配左前列并范围匹配另外一列 只访问索引的查询 使用限制: 如果不是按照索引最左列查找,则无法使用索引 使用索引时不能跳过索引中的列,否则只能部分使用或不能使用 NOT IN 和 <> 操作无法使用索引 如果查询中有某个列的范围查询,则其右边所有列都无法使用索引…
网站打开慢如何排查 1.打开网页, 用谷歌浏览器F12, 查看network: 哪个加载时间长就优化哪个 2.如果是数据库问题 2.1 查看大体情况 # top # uptime  //load average 负载 mysql> show full processlist; 2.2 查看慢查询日志: long_query_time = 1 log-slow-queries = /data/3306/slow.log 日志分析工具: mysqldumpslow  mysqlsla  myprof…
一.以下情况需要创建索引 1.主键自动建立唯一索引 2.频繁作为查询条件的字段应该创建索引 3.查询中与其他表关联的字段,外键关系建立索引 4.单键/组合索引的选择问题,组合索引性价比更高 5.查询中排序的字段,排序字段若通过索引去访问将大大提交排序速度 6.查询中排序或者分组字段 (分组会先进行排序再进行分组) 二.以下情况不要创建索引 1.表记录太少 2.经常增删改的表或者字段 3.Where条件里用不到的字段不创建索引 4.过滤性不好的不适合建索引…
一.查询语句的生命周期 1.MYSQL服务器监听3306端口 2.验证访问用户 3.创建MySQL线程 4.检查内存(Qcache),当查询命中缓存,MYSQL立刻返回结果,跳过解析.优化.执行阶段.若没有缓存,则继续以下步骤: 5.解析SQL 6.生成查询计划 7.打开表 8.检查内存(Buffer Pool) 9.到磁盘取数据 10.写入内存 11.返回数据给客户端 12.关闭表 13.关闭线程 14.关闭连接 二.MYSQL架构 三.MYSQL连接数 MYSQL默认最大连接数是100,在大…
一 当发现程序运行比较慢的时候,首先排除物力资源问题之后,就将注意力转向mysq数据库: 1.首先确定运行慢的sql语句: mysql> show full processlist; 2.确认低效的查询:多次执行第一步发现time耗费大的sql语句.查看耗费的时间. 3.为sql生成一个执行计划query Execution plan(QEP) mysql> explain select * from tbal_name where ...; 4.查看创建表的语句: show create t…
这一篇笔记的mysql优化是注重于查询优化,根据mysql的执行情况,判断mysql什么时候需要优化,关于数据库开始阶段的数据库逻辑.物理结构的设计结构优化不是本文重点,下次再谈 查看mysql语句的执行情况,判断是否需要进行优化 当感觉操作数据库查询语句速度变慢,不符合生产效率要求时,可按照以下步骤进行查看 1. 慢查询的开启与捕获,查看可能是哪些SQL语句造成的查询速度慢 2. explain+SQL语句 3. show profile分析SQL语句在服务器内执行细节和生命周期情况 4. 通…
1.数据类型 1.1.几个参考优化原则 a.  更小的通常更好 i.更小的数据类型,占用更少磁盘.内存和CPU缓存,需要的CPU周期更少 ii.如果无法确定哪个数据类型是最好的,就选择不会超过范围的最小类型 b.  简单就好 i.简单数据类型的操作仅需少量的CPU周期,EX:整形比字符操作代价更低 c.  尽量避免null i.null将使索引.索引统计和值比较更复杂. ii.可null的列需要更多空间 iii.在MyISAM引擎里甚至还可能导致固定大小的索引变成可变大小的索引 1.2.整数类型…