mysql第一天 架构

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云解析 DNS,旗舰版 1个月
简介: <div class="markdown_views"><h3 id="架构">架构</h3><p>mysql最大的特色就是把查询处理与 实际的数据存储和提取(存储引擎)的操作分开了。其整体的架构如下: <br><img src="http://img.blog.csdn.net/20150630171453150" alt="这里写图片描述" title=""></p>

架构

mysql最大的特色就是把查询处理与 实际的数据存储和提取(存储引擎)的操作分开了。其整体的架构如下:
这里写图片描述

  • Connectors 看到JDBC就懂起了,是连接mysql的各种客户端
  • Connection Pool 用于创建用户连接,缓存连接线程,做连接池。 还有鉴权
    修改my.ini重启可以修改最大连接数:
max_connections=200

查看当前变量配置:

SHOW VARIABLES like 'max_c%';

下面的命令还能查看具体的当前连接的信息:

 SHOW processlist;

虽然mysql自带了连接池,但是更多的还是使用客户端连接池的方式。
基本的原理就是一次建立连接之后缓存,然后所有调用连接的地方都从池中取封装之后的
在关闭池中取出的连接时不会真正的关闭连接,而是放回池中,这样就减少了鉴权,三次握手等等操作,增加性能。

  • SQL Interface
    内置函数,DML, DDL,存储过程,视图,触发器,都在这边。
  • Parser
    解析器, 主要有两个功能。验证sql语句是否正确, 把sql语句解析为数据结构,以后只使用这个结构。
    解析器的功能基本上都是这样的,比如Spring中也有xml的解析器也是先转化为一个数据结构之后使用这个数据结构。
  • Optimizer
    优化器。 记得JVM也是有优化器的,会进行重排序呀,以及解释语法糖啊等等操作。
    解析器解析成树,然后进行重写查询,决定表的读取顺序,以及选择合适的索引的操作。在解析查询之前会先检查缓存,如果命中就没有解析优化和执行的过程。
    这里有一个更好的说明:http://blog.csdn.net/whyangwanfu/article/details/1943021
  • Cache & Buffer
    缓存,执行查询语句的时候会先查缓存,如果命中则直接返回,如果没命中才去查sql语句
  • Managerment Service
    非常强大的管理功能, 监控,备份,还原, 镜像, 集群。。。。
  • Storage Engine
    存储引擎,

常用的存储引擎

SHOW TABLE STATUS like 'biz_pay_task';

这样可以查看表的各种信息,包括存储引擎

InnoDB

  • 适用于大多数成功少回滚的大量短期事务
  • 使用MVCC来支持高并发
  • 实现了四个隔离级别,默认REPEATEABLE READ
  • 通过间隙锁策略防止幻读的出现

MyISAM

  • 文件分离
  • 恢复慢
  • 支持GIS,全文索引,压缩
  • 表锁,不支持事务

Memmory

这就是Redis呀

Infobright

面向列的存储引擎,适用于数据仓库

选择引擎

可以从如下的几个出发点:
  • 是否需要事务 InnoDb
  • 是否用到全文索引 InnoDB + Sphinx
  • 备份及恢复 InnoDB
  • 日志型, 插入性能要求高, 用MyISAM,还能随时拷贝备库去做分析

进行服务器测量时的一些基本知识:

  • 用响应时间定义服务器新跟那个
  • 最佳开始点是应用程序,而不是数据库,因为他更容易发生问题。
  • 完整的测量会产生大量需要分析的数据,要根据情况对这些数据进行汇总以及细分分析
  • 通常消耗时间的操作时工作和等待:我们通常能够很好的去测量工作时间,但是当cpu使用率很低有等待的情况是却无法很好的测量。
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
5天前
|
存储 SQL 关系型数据库
MySQL进阶突击系列(03) MySQL架构原理solo九魂17环连问 | 给大厂面试官的一封信
本文介绍了MySQL架构原理、存储引擎和索引的相关知识点,涵盖查询和更新SQL的执行过程、MySQL各组件的作用、存储引擎的类型及特性、索引的建立和使用原则,以及二叉树、平衡二叉树和B树的区别。通过这些内容,帮助读者深入了解MySQL的工作机制,提高数据库管理和优化能力。
|
1月前
|
存储 SQL 关系型数据库
Mysql高可用架构方案
本文阐述了Mysql高可用架构方案,介绍了 主从模式,MHA模式,MMM模式,MGR模式 方案的实现方式,没有哪个方案是完美的,开发人员在选择何种方案应用到项目中也没有标准答案,合适的才是最好的。
140 3
Mysql高可用架构方案
|
2月前
|
监控 关系型数据库 MySQL
深入了解MySQL主从复制:构建高效稳定的数据同步架构
深入了解MySQL主从复制:构建高效稳定的数据同步架构
138 1
|
3月前
|
NoSQL 关系型数据库 MySQL
微服务架构下的数据库选择:MySQL、PostgreSQL 还是 NoSQL?
在微服务架构中,数据库的选择至关重要。不同类型的数据库适用于不同的需求和场景。在本文章中,我们将深入探讨传统的关系型数据库(如 MySQL 和 PostgreSQL)与现代 NoSQL 数据库的优劣势,并分析在微服务架构下的最佳实践。
|
1月前
|
SQL 存储 缓存
【赵渝强老师】MySQL的体系架构
本文介绍了MySQL的体系架构,包括Server层的7个主要组件(Connectors、Connection Pool、Management Service & Utilities、SQL Interface、Parser、Optimizer、Query Caches & Buffers)及其作用,以及存储引擎层的支持情况,重点介绍了InnoDB存储引擎。文中还提供了相关图片和视频讲解。
【赵渝强老师】MySQL的体系架构
|
18天前
|
SQL 存储 关系型数据库
MySQL进阶突击系列(01)一条简单SQL搞懂MySQL架构原理 | 含实用命令参数集
本文从MySQL的架构原理出发,详细介绍其SQL查询的全过程,涵盖客户端发起SQL查询、服务端SQL接口、解析器、优化器、存储引擎及日志数据等内容。同时提供了MySQL常用的管理命令参数集,帮助读者深入了解MySQL的技术细节和优化方法。
|
4月前
|
SQL 关系型数据库 MySQL
(二十五)MySQL主从实践篇:超详细版读写分离、双主热备架构搭建教学
在上篇《主从原理篇》中,基本上把主从复制原理、主从架构模式、数据同步方式、复制技术优化.....等各类细枝末节讲清楚了,本章则准备真正对聊到的几种主从模式落地实践,但实践的内容通常比较枯燥乏味,因为就是调整各种配置、设置各种参数等步骤。
650 3
|
SQL 缓存 NoSQL
MySQL架构与SQL的执行流程_2
MySQL架构与SQL的执行流程_2
153 0
MySQL架构与SQL的执行流程_2
|
SQL 缓存 网络协议
MySQL架构与SQL的执行流程_1
MySQL架构与SQL的执行流程_1
147 0
MySQL架构与SQL的执行流程_1
|
12天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
81 15

推荐镜像

更多
下一篇
DataWorks