网站建设登录界面设计步骤,建筑安全网,网站建站方案书,wordpress 中文编辑器目录MySQL系统架构连接器查询缓存分析器优化器执行器MySQL系统架构 大体来说#xff0c;MySQL分为Server层和引擎层两部分。
Server层包含链接器、查询缓存、分析器、优化器和执行器#xff0c;而引擎层负责的是数据的存储和读取#xff0c;支持InnoDB、Myisam、Memory等多…
目录MySQL系统架构连接器查询缓存分析器优化器执行器MySQL系统架构 大体来说MySQL分为Server层和引擎层两部分。
Server层包含链接器、查询缓存、分析器、优化器和执行器而引擎层负责的是数据的存储和读取支持InnoDB、Myisam、Memory等多种存储引擎默认InnoDB。
连接器
mysql -h$ip -P$port -u$user -p如果输入的密码不对会收到Access denied for user的错误如果输入密码正确连接器会查询出权限表中此账户所拥有的权限这个连接后续所有的权限判断、都依赖于此时查出来的权限。
这就意味着一个用户成功建立连接后即使你用管理员账号对这个用户的权限做了修改也不会影响已经存在连接的权限。修改完成后只有再新建的连接才会使用新的权限设置。可以通过show processlist;命令查看已经建立的连接
连接建立后如果长时间没有客户端请求那么超过8个小时后连接会自动断开这个时间由wait_timeout参数控制。这个时候需要重连才能继续访问MySQL。
有时候我们会发现MySQL占用内存涨的特别快这是因为MySQL在执行过程中临时使用的内存是管理在长连接对象中的这些内存占用在连接断开的时候才会重置。所以长连接在运行过程中可能会因为占用内存过大而被系统杀掉从现象看就是MySQL服务重启了。有以下两种解决方案
定期断开长连接或者执行完一个占用内存比较大的查询后、断开连接之后的请求再重连也可以通过执行mysql_reset_connection命令重置连接他会将连接重置为连接刚刚建立时的状态MySQL5.7及以上。
查询缓存
MySQL在拿到一个查询请求之后会首先到查询缓存中查看是否有这条查询语句的缓存。缓存时一个K-V结构K就是这条语句V是具体的查询结果。如果找到了缓存那么直接返回否则在进行具体查询并将结果更新到查询缓存中。
但是在MySQL8之后已经将查询缓存的功能整体移除了因为这是一种弊大于利的功能只要对这张表的任何数据有更新操作那么这张表所涉及的所有查询缓存都会失效。当然一些不经常修改系统变量之类的表仍适合使用查询缓存功能总体来说弊大于利。
分析器
如果没有命中查询缓存接下来就会轮到分析器工作。
首先经过词法分析它会识别出SQL中的字符串分别代表什么比如select表示查询id代表主键列等然后进入语法分析判断SQL语句是否符合语法标准如果语法不对会报出You have an error in your SQL syntax的错误。
优化器
优化器会选择使用哪个索引当有多表联合查询的时候、决定各个表的连接顺序。
执行器
真正执行的地方最终扫描行数可以在rows_examined看到