Mysql基础架构

 

1连接器,负责跟客户端建立连接,获取权限,维持和管理连接.

2查询缓存,

当执行查询时发现之前有这个查询语句的记录,则直接返回结果,但是,大多数情况下不建议使用缓存,因为即使花大力气存起查询的结果,在更新一个表后,会使得这个表相关的所有缓存失效,导致缓存的命中率并不高,还带来额外的开销。

3分析器,

分析器会进行词法分析和语法分析,将不符合语法的语句发会错误提醒

4 执行器

执行器在开始执行前会先判断当前用户是否有这张表的权限,然后根据MySQL所使用的引擎所提供的接口去执行语句。

2.日志系统

2.1.redo log

redo log使用的是MySQL的WAL(Write-Ahead-Logging)技术,特点是先写日志 ,再写磁盘。当有记录要更新时,先把记录写到redo log里,等系统比较空闲时再写入磁盘。InnoDB的redo log时固定大小的,从头开始写,写到末尾就又回到开头循环写,用checkpoint和write pos两个指针来指示有效记录。当数据库发生异常重启时,即使数据还没有写入磁盘,但因为redo log中保存了该记录,可以保证之前提交的记录都不会丢失,这能力称为crash-safe

2.2.binlog

redo log是引擎所使用的日志,而MySQL的Server层也有一个日志,被称为binlog。 与redo log不同,binlog只是归档日志,只记录MySQL的原始逻辑操作,例如给A表的第三行的日字段设置为C。而redo log是物理日志,记录

对某个数据页做修改。因为没有精确到某一布物理操作,binlog并不能实现crash-safe,但它也有自己的作用:binlog可以使你通过回放让MySQL系統退回之前的状态 ,因为biniog是追加写的,不会費盖以前的日志,所以你可

以退回到任意一个时刻,另外binlog 是MySQL的server 层的日志,所以无论使用什么引擎都可以使用,而redo log需要innoDb才能使用

 

2.3两阶段提交

Mysql 在写这两个日志的时候,会先写入Redo log 在写入Binlog然后再提交,这样能保证两个日志的一致性

  • 6
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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、付费专栏及课程。

余额充值