后端程序员在面试中,经常会被问到SQL调优的操作,于是我也是去补习了一下这方面的知识,感谢各方大佬提供的点子,这里总结如下。...3- 通常来说,把可以为NULL的列改为NOT NULL不会对性能提升有多少帮助,只是如果计划在列上创建索引,就应该将该列设置为NOT NULL。...6- MySQL如下表达式不会使用索引: select * from where id + 1 = 5 虽然我们很容易看出来id+1=5等价于id=4,但是MySQL无法自动解析这个表达式,使用函数是同样的道理...因此,在创建表的时候,为了获得更好的性能,我们可以将表中字段的宽度设得尽可能小。当然这对于INT这类型字段属性来讲就画蛇添足了。...如果有对应的索引,通常效率会不错,否则,MySQL需要做大量的文件排序操作。
mysql调优思路: 1.数据库设计与规划--以后再修该很麻烦,估计数据量,使用什么存储引擎 2.数据的应用--怎样取数据,sql语句的优化 3.mysql服务优化--内存的使用,磁盘的使用 4....第二种方法是对 MySQL 服务器(也称为 mysqld)进行调优。对这个进程进行调优意味着适当地分配内存,并让 mysqld 了解将会承受何种类型的负载。加快磁盘运行速度不如减少所需的磁盘访问次数。...作为奖励,mysqlard 使用自己搜集到的一些信息针对如何对服务器进行调优给出一些建议。 搜集 SHOW STATUS 信息的另外一个工具是 mysqlreport。...这是对服务器进行调优的一个非常好的工具,因为它对状态变量进行适当计算来帮助确定需要修正哪些问题。...结束语 本文介绍了对 MySQL 进行调优的一些基础知识,并对这个针对 LAMP 组件进行调优的 3 部分系列文章进行了总结。
修改 my.cnf 后记得重启 MySQL 。重启后再运行 MySQLTuner 检查。 另外需要注意的是 MySQL 需要启动 24 小时候再运行 MySQLTuner ,不然有些内容会不准。...【从下面的参数可以发现这个工具还支持远程主机的体检】 Connection and Authentication --host Connect to a remote...mysqladmin Path to a custom mysqladmin executable --mysqlcmd Path to a custom mysql...template file --verbose Prints out all options (default: no verbose) 例如我有1台服务器,上面跑的是多实例的mysql.../mysqltuner.pl --socket /data/multi_instance/3306/mysql.sock
CPU使用率 工具: vmstat 检查应用性能时,应该首先审查CPU时间。 代码优化的目的是提升而不是降低(更短时间段内的)CPU的使用率。...磁盘使用率 工具: iostat 对于所有应用来说,监控磁盘使用率非常重要。即便不直接写磁盘的应用,系统交换仍会影响它们的性能。...jvisualvm: 监视JVM的GUI工具,可以用来剖析运行的应用,分析JVM堆转储。...故障诊断和性能监控的可视化工具 Visual VM是一个功能强大的多合一故障诊断和性能监控的可视化工具,它集成了多种性能统计工具的功能,使用Visual VM可以替代jstat、jmap、jhat、jstack...等工具。
前言 说起mysql的调优一般都会想到sql优化、索引、看执行计划,除了这些在创建表时也要下功夫,比如说字段的类型、数据的冗余度,以及sql运行过程中性能的监控都很重要。...三、合理使用索引 索引的建立可以大大提高mysql的检索效率,但是在insert、update、delete会降低更新表的速度,因为更新表时不仅要保存数据还要维护索引文件。...特殊名词 回表:mysql默认给主键创建索引,其叶子节点存放行数据。普通索引叶子节点存放主键,当使用普通索引查询到主键时会再一次根据主键查询一次索引树,会有两次的树的操作,这个行为是回表。...此时要检查sql语句中索引匹配方式 using temporary:建立临时表保存中间结果 using indexing:表示查询时覆盖索引 using where:使用where条件过滤 五、sql的性能监控...编辑 performance schema 本身是一个数据库,有80+张表,存储mysql运行过程中的性能相关的数据。
《MySQL性能调优,这个工具最有用(上)》 详细叙述了explain结果中最重要的type字段(连接类型)的含义。...画外音:本例中,sex字段区分度不高,添加索引对性能提升有限。...这类SQL语句往往性能较好。 问题来了,什么样的列数据,会包含在索引树上呢?...这类SQL语句性能也较高,但不如Using index。 问题来了,如何优化为Using index呢?...结尾: explain是SQL优化中最常用的工具,搞定type和Extra,explain也就基本搞定了。
本文汇总了MySQL DBA日常工作中用到的些工具,方便初学者,也便于自己查阅。...oprofile 【这个工具太厉强大,但是需要我们先安装带debug的kernel才行,具体请自行查阅文档】 基础设施没问题后,我们才可以去考虑MySQL的参数调优及性能优化。...常用的性能分析工具有: mytop、innotop、orzdba、dodba、mysqltuner.pl。.../doDBA-help 查看帮助 收集Linux性能数据 ./doDBA-h=192.168.2.11 -sys # 通过ssh远程连接去获取信息 ? 搜集MySQL性能数据 ....搜集InnoDB性能数据 ./doDBA-h=127.0.0.1 -innodb ? 搜集MySQL及Linux性能数据 ./doDBA-h=127.0.0.1 -myall ?
所以我们深入了解MySQL的基于开销的优化器,还可以获得很多可能被优化器考虑到的访问策略的细节,以及当运行SQL语句时哪种策略预计会被优化器采用。...常用的类型有: ALL、index、range、 ref、eq_ref、const、system、NULL(从左到右,性能从差到好) ALL:Full Table Scan, MySQL将遍历全表以找到匹配的行...如将主键置于where列表中,MySQL就能将该查询转换为一个常量,system是const类型的特例,当查询的表只有一行的情况下,使用system NULL: MySQL在优化过程中分解语句,执行时甚至不用访问表或索引...在这种情况下,可以通过检查WHERE子句看是否它引用某些列或适合索引的列来提高你的查询性能。...,这发生在对表的全部的请求列都是同一个索引的部分的时候,表示mysql服务器将在存储引擎检索行后再进行过滤 Using temporary:表示MySQL需要使用临时表来存储结果集,常见于排序和分组查询
前言 ---- 工具的进化一直是人类生产力进步的标志,合理使用工具能大大提高我们的工作效率,遇到问题时,合理使用工具更能加快问题排查的进度。...介绍 ---- 引子 在排查性能问题时,我们通常会把线程栈 dump 出来,然后使用 grep --no-group-separator -A 1 java.lang.Thread.State jstack.log...产生这个问题的主要原因是,我们的线程栈是有调用关系的,即我们需要考虑线程栈的 调用链 和 出现频率 两个维度,而单一的文本表现这两种维度比较困难,所以,著名性能分析大师 brendan gregg 就提出了火焰图...我们更应该关注的是火焰图顶部的一些 “平顶山”,顶部说明它没有子调用,方块宽说明它耗时长,长时间 hang 住,或者被非常频率地调用,这种方块指向的调用才是性能问题的罪魁祸首。...做开发越久,越能感受得到工具的重要性,所以我准备加一个专题来专门介绍我使用的各种工具。当然,这也就更需要我更多地了解、使用和总结新的工具了。
性能观察工具: 静态性能工具 性能压测工具: 性能调优工具 sar perf-tools 追踪工具 BPF性能工具:
索引用于快速找出在某个列中有一特定值的行,如果不使用索引MySQL必须从第l条记录开始读完整个表,直到找出相关的行.表越大,查询数据所花费的时间越多,如果表中查询的列有一个索引,MySQL能快速到达某个位置去搜寻数据文件...UNION RESULT => 从UNION表中获取结果的SELECT type 访问类型排列,只要能够达到ref,range级别就已经不错了,性能效率。...最差的性能。...以下我们加上全部索引字段,从此下面这条sql性能更高了。...-----+-------------+ 1 row in set (0.00 sec) 覆盖索引,就是说你建立的复合索引是 x,y,z 那么你在查询是应该要覆盖这些索引,这样才能让索引,发挥其最大的性能
本文涉及:MySQL自带的性能测试工具mysqlslap的使用及几个性能调优的方法 性能测试工具—mysqlslap mysqlslap是MySQL自带的一款非常优秀的性能测试工具。...create-schema='test' --query='select * from u_trade_pay_order limit1000;' --number-of-queries=10 影响MySQL...性能的原因 连接数不够 当连接数使用超过85%以上就说明连接数已经快要不够用了 连接数相关查看方法 show global status like 'Max_used_connections';...show variables like 'max_connections%'; 连接数不够的原因 连接数设置过低或过高 慢查询导致IO阻塞,导致连接长时间不释放 SQL执行完,连接未释放 修改MySQL
概述 jinfo 是 JDK 自带的命令,可以用来查看正在运行的 java 应用程序的扩展参数,包括Java System属性和JVM命令行参数;也可以动态的修...
概述 Jstat是JDK自带的一个轻量级小工具。...全称“Java Virtual Machine statistics monitoring tool”,它位于java的bin目录下,主要利用JVM内建的指令对Java应用程序的资源和性能进行实时的命令行的监控
概述 jstack是jdk自带的线程堆栈分析工具,使用该命令可以查看或导出 Java 应用程序中线程堆栈信息。 Jstack 用法 image 参数说明: -l 长列表.
磁盘性能对数据库的读写能力影响很大,如何从多个角度监控数据库的写性能就变得至关重要,当写性能成为瓶颈时我们又该如何调优呢?...Innodb_buffer_pool_pages_dirty/Innodb_buffer_pool_pages_total,通过该比值可以看出脏页的占比情况,如果该系统脏页占比持续增高,说明该系统是以写为主,根据情况进行调优...二、写压力调优参数 1、刷新脏页的频率 mysql> show variables like '%innodb_lru_scan_depth%'; #默认1024,遍历lru list刷新脏页,值越大,...,自然也就会带来一定的性能压力。...4、内存脏页占比控制 mysql> show variables like '%innodb_max_dirty_pages_pct%'; #在内存buffer pool空间允许的范围下,可以调大脏页允许在内存空间的占比
这与Solaris的pmap工具比较相似。 ?...想要浏览heap dump,你可以使用jhat(Java堆分析工具)读取生成的文件。
WHERE column1 = -column2 3 还是可以带来查询性能的优化的。...针对专门操作符的调优 前面,讲的是关于查询条件的一般规则,在这一节中,将讨论如何使用专门的操作符来改进 SQL 代码的性能。...当一些优化器发现查询中存在 OR 操作符时,就不使用索引查询,所以在这种情况下,并且只有在这种情况下,UNION 才比 OR 性能更高。...以上是作者对如何提高 SQL 性能的一些总结,这些规则并一定在所有的数据库系统上都能带来性能的提高,但是它们一定不会对数据库的性能带来下降,所以掌握并使用这些规则可以对数据库 应用程序的开发有所帮助。...本文总结的是一些 SQL 性能调优的比较初级的方面,SQL 调优还包括 Order by,Group by 以及 Index 等等。
概述 jps 命令类似与 linux 的 ps 命令,但是它只列出系统中所有的 Java 应用程序。 通过 jps 命令可以方便地查看 Java 进程的启动类、...
概述 在JDK1.7以后,新增了一个命令行工具 jcmd。他是一个多功能的工具,可以用它来导出堆、查看Java进程、导出线程信息、执行GC、还可以进行采样分析(jmc 工具的飞行记录器)。...Perfcounter.print:打印目标Java进程上可用的性能计数器。性能计数器的列表可能会随着Java进程的不同而产生变化。...命令:jcmd pid PerfCounter.print 描述:查看指定进程的性能统计信息。...1.JRF 相关命令 JRF 功能跟 jmc.exe 工具的飞行记录器的功能一样的。...导出的 dump 文件,可以使用MAT 或者 Visual VM 等工具进行分析。 注意:如果只指定文件名,默认会生成在启动 JVM 的目录里。
领取专属 10元无门槛券
手把手带您无忧上云