当前位置: 首页 > news >正文

制作单页网站教程视频公司培训网站需要广播证吗

制作单页网站教程视频,公司培训网站需要广播证吗,wordpress批量添加连接,什么软件能自己做网站目录 一、MySQL缓存机制概述 二、MySQL整体架构 三、SQL查询执行全流程 四、MySQL 8.0为何移除查询缓存? 五、MySQL 8.0前的查询缓存配置 六、替代方案:应用层缓存与优化建议 总结 一、MySQL缓存机制概述 MySQL的缓存机制旨在提升数据访问效率&am…

目录

一、MySQL缓存机制概述

二、MySQL整体架构

三、SQL查询执行全流程

四、MySQL 8.0为何移除查询缓存?

五、MySQL 8.0前的查询缓存配置

六、替代方案:应用层缓存与优化建议

总结


一、MySQL缓存机制概述

MySQL的缓存机制旨在提升数据访问效率,主要分为两类:一级缓存二级缓存

  1. 一级缓存(InnoDB Buffer Pool)

    • 作用:存储数据和索引,减少磁盘I/O操作,由InnoDB存储引擎管理。

    • 特点:自动缓存热点数据,通过LRU算法淘汰冷数据。

    • 优化建议:通过参数 innodb_buffer_pool_size 调整缓存大小(通常设置为物理内存的70%-80%)。

  2. 二级缓存(Query Cache,MySQL 8.0前支持)

    • 作用:缓存SELECT查询的结果,直接返回重复查询的结果,避免重复计算。

    • 问题:在高并发写入场景中,频繁的缓存失效导致性能下降。


二、MySQL整体架构

MySQL采用分层设计,核心分为三层:

  1. 服务层(Service Layer)

    • 负责SQL解析、优化和执行,包含三大组件:

      • 解析器(Parser)

        • 词法分析:拆分SQL语句为关键字、表名等标记。

        • 语法分析:生成解析树(Parse Tree),验证语法正确性。

        • 语义检查:验证表、列是否存在及权限。

      • 优化器(Optimizer)

        • 逻辑优化:重写查询,消除冗余条件。

        • 物理优化:选择索引、连接方式(如JOIN顺序),生成成本最低的执行计划。

      • 执行器(Executor)

        • 权限校验后调用存储引擎接口执行计划,返回结果。

  2. 引擎层(Storage Engines)

    • 支持多种存储引擎(如InnoDB、MyISAM),负责数据存储和读写。

  3. 文件系统层(File System)

    • 存储表结构文件(.frm)、数据文件(.ibd)、日志文件(redo/undo log)等。


三、SQL查询执行全流程

一条SQL查询从发起到返回结果的完整流程:

  1. 客户端请求

    应用程序发送SQL语句到MySQL服务端。
  2. 解析器处理

    解析器验证语法并生成解析树。
  3. 优化器生成执行计划

    基于统计信息(如表大小、索引选择性)选择最优执行路径。
  4. 权限检查

    确认用户对目标数据的访问权限。
  5. 缓存查询(MySQL 8.0前)

    查询缓存(Query Cache)命中则直接返回结果。
  6. 执行器调用引擎

    执行器按计划调用存储引擎接口:

                (1)日志记录:写入redo log保证事务持久性。

                (2)一级缓存(Buffer Pool):若数据已在内存,直接读取;否则从磁盘加载。

    7. 结果返回与缓存更新

          返回结果集,更新缓存(若涉及写操作,缓存失效)。


四、MySQL 8.0为何移除查询缓存?
  • 高并发写入场景:频繁的DML操作导致缓存频繁失效,维护成本高。

  • 锁竞争:查询缓存需要全局锁,影响并发性能。

  • 替代方案成熟:推荐使用外部缓存(如Redis)或InnoDB缓冲池优化。


五、MySQL 8.0前的查询缓存配置
-- 启用查询缓存
SET GLOBAL query_cache_type = 1;  -- 1为启用,0为关闭
-- 设置缓存大小(64MB)
SET GLOBAL query_cache_size = 64 * 1024 * 1024;
-- 执行查询(命中缓存直接返回)
SELECT * FROM users WHERE id = 1;

六、替代方案:应用层缓存与优化建议
  1. 外置缓存(如Redis/Memcached)

  • 缓存热点数据(如用户信息、商品详情),降低数据库压力。
  • 支持分布式缓存,适合高并发场景。

      2. InnoDB缓冲池优化

  • 调整 innodb_buffer_pool_size 提升内存利用率。

  • 监控命中率:SHOW STATUS LIKE 'innodb_buffer_pool_read%';

  3. 本地缓存(如Guava Cache)

  • 适用于单机高频访问的小数据量场景。


总结

MySQL的缓存机制和架构设计是其高性能的核心。尽管MySQL 8.0移除了查询缓存,但通过合理利用InnoDB缓冲池、应用层缓存及优化执行计划,仍能显著提升性能。理解组件协作与执行流程,是数据库调优的关键基础。

http://www.yayakq.cn/news/930289/

相关文章:

  • 如何网站备案住房和城乡建设部政务服务门户网站
  • 南充做网站电话电子商务搭建平台
  • 网站管理登录企业网站建设需求文档
  • 手机版网站制作模板定制礼品公司
  • 企业网站建设设计wordpress用户发文章数量
  • 网站建设有哪些基本流程杭州网站建设杭州
  • 巴中哪里可以做公司网站网站开发中要做哪些东西
  • 南京网站设计公司兴田德润优惠吗手机网站建设咨询电话
  • 全国十大网站设计工作室做go分析和kegg分析网站
  • 中鼎国际建设集团网站做网站刷东西
  • 网站建设好后能直接打开吗谷歌云做网站
  • 自己怎么建个网站赚钱女装网站建设文献综述
  • 寮步仿做网站自助建站网站的宣传手册
  • 搜索引擎优化简历北京seo优化网站建设
  • php 网站做分享功能转转免费假链接制作器
  • 陕西手机网站建设公司小红书笔记推广
  • lol做框网站深圳互联网网页设计招聘
  • 深圳食品网站建设咸阳微网站建设
  • 如何替换网站上的动画线下推广方式都有哪些
  • 在凡科建设网站的流程wordpress缓存接口数据
  • 哪个公司制作企业网站wordpress 谷歌搜索
  • 备案网站首页地址微信微商软件
  • 网站设计奖上地网站制作
  • 手机端视频网站模板重庆网站开发公
  • 帮忙做ppt的网站株洲网站建设服务公司
  • 网站改版注意事项房地产政策政策最新消息
  • 在线做网站 自动生成手机版电商培训机构需要什么资质
  • 网站集约化建设优点厦门做网站公司排名
  • 个人备案网站做企业网可以吗佛山网站建设公司有哪
  • 门户网站建设管理总则苏州三笑网络科技有限公司