MySQL基础架构

mysql 基本架构示意图:

连接器:

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

平常使用中要尽量使用长连接,但是当全部使用长连接后,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基础架构包括客户端、连接处理层、解析器、优化器和存储引擎。首先,客户端(比如jdbc和PHP)通过连接处理层连接到MySQL服务器。然后,解析器对SQL语句进行解析,将其转换为解析树。接下来,优化器对SQL语句进行优化,选择最优的执行计划。最后,优化器调用存储引擎的接口来执行SQL语句。存储引擎负责处理数据的存储和检索操作。这种架构允许MySQL在各个层次上进行优化和扩展,提供高效的数据访问和处理能力。 MySQL基础架构是游戏开发中使用MySQL的重要组成部分。在游戏开发中,通过MySQL可以实现数据的持久化存储和查询操作。首先,需要进行数据库设计,包括确定表结构和关系等。然后,通过数据查询可以获取游戏中所需的数据。同时,还需要考虑数据的安全性,比如使用合适的权限管理和加密机制来保护数据的安全性。通过掌握MySQL的基础知识和方法,可以更好地进行游戏开发和数据管理。 MySQL的起源可以追溯到1994年,由瑞典的MySQL AB公司开发。MySQL AB公司于2008年被Sun Microsystems收购,之后Sun Microsystems又被Oracle Corporation收购。MySQL是一种开源的关系型数据库管理系统,广泛应用于各种规模的应用程序和网站。MySQL具有高性能、可靠性和可扩展性,成为了最受欢迎的数据库管理系统之一。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [MySQL(一):架构体系](https://blog.csdn.net/Edwin_Hu/article/details/120910748)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [MySQL如何在游戏开发中使用](https://download.csdn.net/download/milk416666/88259896)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值