MySQL基础架构

mysql 基本架构示意图:

MySQL基础架构_第1张图片

连接器:

负责跟客户端建立连接、获取权限、维持和管理连接。

平常使用中要尽量使用长连接,但是当全部使用长连接后,mysql占用内存会涨的特别快,原因是mysql在执行过程中临时使用的内存是管理在连接 对象里面的,这些资源会在连接断开的时候才释放,大量长连接积累下来会导致内存占用太大,会被系统强行杀掉OOM,从现象看就是mysql异常重启了。

解决方案:

1.定期断开长连接。一段时间后断开连接,会程序里面判断执行一个占用内存的大查询后,断开连接,之后查询再重连。

2.mysql5.7以上,可以在每次执行一个比较大的操作后,通过执行mysql_reset_connection 来重新初始化连接资源,这个过程不需要重连和重新权限验证,但会将连接恢复到刚刚创建完的状态

 

查询缓存

执行过的语句和结果 会以key-value形式存在内存中,如何能命中key,value会直接返回

但是查询缓存往往利大于弊,大多数情况下不被建议使用,因为查询缓存的失效非常频繁,只要对该表有更新,这个表上的查询缓存都会被清空,对于更新压力大的数据来说,查询缓存命中率会非常低,如果对于业务是一张静态表,很长时间才会更新就比较适合。

mysql也提供了按需使用的方式,参数 query_cache_type 设置成 DEMAND,这样的sql语句默认不适用查询缓存,只有当确认要使用查询缓存的语句是,可以用SQL_CACHE指定(该功能在mysql8.0版本去除了)

mysql> select SQL_CACHE * from T where ID=10;
 

分析器

对sql语句进行词法分析,然后进行语法分析

 

优化器

当表里有多个索引的时候,会决定使用哪个索引,在多表关联的时候,决定各个表的连接顺序,优化器作用是决定选择使用具体的一个方案达到效率最大化

 

执行器

会先判断你对语句是否有权限,有权限才会继续去执行,执行器会遍历所有满足条件的行组成记录作为结果集返回给客户端。

慢日志中的rows_examined可以表示语句执行过程中扫描了多少行,该值是执行器每次调用引擎获取数据行累加的。

在一些特定的场景下,执行器每调用一次,在引擎内部会扫描多行,所以rows_examined有时候并不是完全相同的

 

 

 

 

 

 

 

你可能感兴趣的:(mysql,mysql)