首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

高性能MySQL(1)——MYSQL架构

mysql 数据库的逻辑架构如下图 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Jx9utej6-1603348859176)(/Users/marron27/Documents.../lizhengi/MySQL/高性能MySQL/T.Mysql逻辑图.png)] 从上图可以看出My SQL逻辑结构大致可以分为三层: 第一层结构主要处理客户端与mysql服务端的连接、授权认证、安全等...三、事务 3.1、事务的ACID特性 数据库的事务处理的原则是保证ACID的正确性。...(状态更改一致性) 隔离性(Isolation):数据库系统提供一定的隔离机制,保证事务在不受外部并发操作影响的“独立”环境执行。这意味着事务处理过程中的中间状态对外部是不可见的。...参考: 《高性能 MySQL 第三版》 MySQL逻辑架构简介 mysql的并发控制

90320

高性能 MySQL 笔记

MySQL架构和历史 MySQL逻辑架构 第一层处理网络连接等, 比如链接认证授权等 第二层是 MySQL 的核心, 用来解析优化 SQL 语句, 设计缓存, 以及各种函数的实现, 包括存储过程, 触发器...客户端连接]auth[检查用户名密码]access[检查是否有对应资源的处理权限]query[执行SQL 操作]start-->authauth-->accessaccess-->query 并发控制 MySQL...会在两个层面做并发控制: 服务器层和存储引擎层 读写锁 读锁(共享锁)是共享的, 互相不阻塞 写锁(排他锁)是排他的, 给定时间内, 只有一个用户能写入 表锁在服务器层实现, 行锁在存储引擎层实现 事务 数据库事务具有...对其他的事务不可见, 即只对自己事务内部的数据有影响, 也叫不可重复读 REPEATEABLE READ 可重复读, A 事务本身对数据的修改对 A 事务后边的语句也不起作用, 所有的 SQL 操作的数据都来自数据库...存储引擎 InnoDB 支持行级锁 支持事务 全表使用 B+ tree 实现 数据只存在叶子节点上 MyISAM 不支持行级锁, 只支持表锁 数据文件和索引文件分开 不支持事务 可以通过压缩表技术提高性能

1.2K90

系列 | 高性能存储-MySQL数据库之存储过程揭秘

DBASK小程序已经开设“MySQL 数据库专栏”,欢迎大家关注!...提高性能。因为使用存储过程比使用单独的 SQL语句要快。 存在一些只能用在单个请求中的MySQL元素和特性,存储过程可以使用它们来编写功能更强更灵活的代码(在下一章的例子中可以看到。)...换句话说,使用存储过程有 3个主要的好处,即简单、安全、高性能。显然,它们都很重要。不过,在将 SQL代码转换为存储过程前,也必须知道它的一些缺陷。...这里有一个需要注意的就是:MySQL命令行客户机的分隔符 如果你使用的是MySQL命令行实用程序,应该仔细阅读此说明。...默认的 MySQL语句分隔符为;(正如你已经在迄今为止所使用的MySQL语句中所看到的那样)。MySQL命令行实用程序也使用;作为语句分隔符。

2.1K30

系列 | 高性能存储-MySQL数据库之存储过程揭秘

DBASK小程序已经开设“MySQL 数据库专栏”,欢迎大家关注!...提高性能。因为使用存储过程比使用单独的 SQL语句要快。 5. 存在一些只能用在单个请求中的MySQL元素和特性,存储过程可以使用它们来编写功能更强更灵活的代码(在下一章的例子中可以看到。)...换句话说,使用存储过程有 3个主要的好处,即简单、安全、高性能。显然,它们都很重要。不过,在将 SQL代码转换为存储过程前,也必须知道它的一些缺陷。 1....默认的 MySQL语句分隔符为;(正如你已经在迄今为止所使用的MySQL语句中所看到的那样)。MySQL命令行实用程序也使用;作为语句分隔符。...这样,存储过程体内的 ;仍然保持不动,并且正确地传递给数据库引擎。最后,为恢复为原来的语句分隔符,可使用 DELIMITER ;。除符号外,任何字符都可以用作语句分隔符。

1.9K70

高性能MySQL学习笔记

高性能MySQL读书笔记。。。 MySQL架构 并发控制 读写锁 在处理并发读或者写时,通过实现一个由两种类型的锁组成的锁系统来解决问题。...READ COMMITED(提交读) 大多数数据库系统的默认隔离级别都是提交读(但MySQL不是)。该隔离级别定义为:一个事物开始时,只能看见已经提交的事务所做的修改。...意思是要用要求的表结构创建一张和源表无关的新表,然后通过重命名和删表操作交换两张表 不是所有的ALTER TABLE操作都会引起表重建,有两种方式: 只修改.frm文件 快速创建myisam索引 创建高性能的索引...索引的三个优点 大大减少服务器需要扫描的数据量 帮助服务器避免排序和临时表 将随机io变为顺序io 高性能的索引策略 独立的列 如果查询中的列不是独立的,则mysql就不会使用索引 前缀索引和索引选择性...压缩(前缀压缩)索引 MyISAM使用前缀压缩来减少索引的大小,从而让更多的索引可以防到内存中,在某些情况下可以极大提高性能

1.3K20

高性能MySQL之缓存

高性能MySQL之缓存 MySQL中的缓存是用来避免所查询的数据需要对磁盘进行访问,我们知道,磁盘上的访问会比内存的访问速度慢得多,所以,如果你的服务器上之部署了一个MySQL的服务,那么为它配置一个大的缓存无疑是明智之举...如果大部分都是Innodb表,那么innodb缓冲池的大小就基本上决定了我们MySQL数据库的性能,我们知道,innodb缓冲池中并不仅仅缓存索引,还包含插入缓冲、锁信息等其他数据结构,innodb存储引擎是严重依赖缓冲池的...,那么MySQL将会跳过所有的阶段,直接从缓存中拿到结果并返回给客户端。...我们可以根据实际情况来设置参数query_cache_min_res_unit的值,如果这个值query_cache_min_res_unit设置的很小,理论上浪费的空间就比较小,但是内存块的申请操作会变得比较频繁,影响数据库的性能...query_cache_wlock_invalidate,如果某个数据表被其他的连接锁住,是否仍然需要从查询缓存中返回结果,默认值是off,意思是数据库将返回其他线程锁住的数据,如果设置为on,则不会从缓存中返回这类数据

1.3K20

MYSQL高性能优化总结

1.1 前言 在进行MySQL的优化之前必须要了解的就是MySQL的查询过程,很多的查询优化工作实际上就是遵循一些原则让MySQL的优化器能够按照预想的合理方式运行而已。 ?...安全 ---> 数据可持续性 性能 ---> 数据的高性能访问 1.3.2 优化的范围有哪些 存储、主机和操作系统方面: 主机架构稳定性 I/O规划及配置 Swap交换分区...OS内核参数和网络问题 应用程序方面: 应用程序稳定性 SQL语句性能 串行访问资源 性能欠佳会话管理 这个应用适不适合用MySQL 数据库优化方面:...(部署zabbix监控平台)pt-query-digest分析慢日志mysqlslap 分析慢日志sysbench 压力测试工具mysql profiling统计数据库整体状态工具 Performance...1.6 数据库优化 SQL优化方向:  执行计划、索引、SQL改写 架构优化方向:  高可用架构、高性能架构、分库分表 1.6.1 数据库参数优化 调整:  实例整体(高级优化,扩展): innodb_thread_concurrency

1.2K40

高性能MySQL(一):MySQL架构与历史

文章目录 前言 MySQL架构与历史 MySQL逻辑架构 连接管理 优化与执行 并发控制 锁粒度 表锁 行级锁 事务 隔离级别 事务日志 前言 我准备开一个新的系列,这是我以前接触不多的新领域...本系列取材于《高性能MySQL》第三版,是我的学习笔记。...---- MySQL架构与历史 MySQL逻辑架构 第二层架构是MySQL比较有意思的部分,大多数MySQL的核心服务功能都在这一层,包括增删查改以及所有的内置函数。...表锁 表锁是MySQL中最基本的锁策略,也是开销最小的策略。它会锁定整张表。...持久性:事务一旦提交,其所做的修改就会永久的保存到数据库中。 隔离级别 隔离性其实比想象的更要复杂。下面简单介绍一下四种隔离级别。 未提交读:性能消耗又大,又没有什么卵用。

87840

Mysql高性能优化规范建议

数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,...500万并不是Mysql数据库的限制,过大会造成修改表结构,备份,恢复都会有很大的问题。 可以用历史数据归档(应用于日志数据),分库分表(应用于业务数据)等手段来控制数据量大小 5....通常存储于文件服务器,数据库只存储文件地址信息 9. 禁止在线上做数据库压力测试 10. 禁止从开发环境,测试环境直接连接生成环境数据库 ---- 数据库字段设计规范 1....因为mysql优化器在选择如何优化查询时,会根据统一信息,对每一个可以用到的索引来进行评估,以生成出一个最好的执行计划,如果同时有很多个索引都可以用于查询,就会增加mysql优化器生成执行计划的时间,同样会降低查询性能...拆分复杂的大SQL为多个小SQL 大SQL逻辑上比较复杂,需要占用大量CPU进行计算的SQL MySQL中,一个SQL只能使用一个CPU进行计算 SQL拆分后可以通过并行执行来提高处理效率 ---- 数据库操作行为规范

1.1K30

高性能MySQL》读书笔记

本系列取材于《高性能MySQL》第三版,是我的学习笔记。...持久性:事务一旦提交,其所做的修改就会永久的保存到数据库中。 隔离级别 隔离性其实比想象的更要复杂。下面简单介绍一下四种隔离级别。 未提交读:性能消耗又大,又没有什么卵用。...数据库服务器的目的是执行SQL语句,所以它关注的是查询或者语句(查询 == 发送给服务器的指令)。 优化:我们假设优化是服务器在一定的工作负载下尽可能的而减少响应时间。...注意,该语句不 是随机生成的,而是分组语句中最差的查询SQL语句) ---- 优秀资料 参考资料来源:Mysql性能瓶颈深度定位分析 我们在性能测试过程中,经常会遇到Mysql出现性能瓶颈的情况,对于数据库来说...支持的数据类型非常多,选择正确的数据类型对于获得高性能至关重要。

35520

高性能Mysql》学习笔记(二)

高性能Mysql》学习笔记(二) 前言 接续上文继续介绍:《高性能Mysql》学习笔记(一)。...mysql 时间线 基准测试 为什么需要基准测试 基准测试策略 基于mysql 单独测试 - 单组件式 对整个系统整体测试 - 集成式 使用整个系统测试原因主要如下 如果不需要关注整体应用,只关注...类似工业标准的测试工具 dbt2 免费的toc-c oltp 测试工具 percona's tpcc-mysql tool mysql 高性能并发作者自己制作 sysbench 多线程系统压测工具 支持...使用 show profile mysql 5.1 之后版本引入,默认是禁用的,但是可以通过服务器变量在连接中动态更改mysql> set profiling = 1 开启后会测量查询执行相关操作的状态...让 Mysql 认为是 第一张表 释放读锁 使用 repair table 来重新创建表的索引。

67630

高性能MySQL【笔记】超详细

,更容易做到高性能和可扩展 * 查询本身效率也可能会有所提升 * 可以减少冗余记录的查询 * 相当于在应用中实现了哈希关联,而不是使用MySQL的嵌套循环关联 4.分解关联查询的场景: * 当应用能够方便地缓存单个查询的结果的时候...,所以可能有安全隐患 * 存储过程会给数据库服务器增加额外的压力,而数据库服务器的扩展性相比应用服务器要差很多 * MySQL并没有什么选项可以控制存储程序的资源消耗,所以在存储过程中的一个小错误,可能直接把服务器拖死...正确地使用内存量对高性能是至关重要的,内存消耗分为两类:可以控制的内存和不可以控制的内存 2.配置内存: * 确定可以使用的内存上限 * 确定每个连接MySQL需要使用多少内存 * 确定操作系统需要多少内存才够用...在这样的环境中,并发可能成为瓶颈 C.平衡内存和磁盘资源 1.配置大量内存最终目的是避免磁盘I/O,最关键的是平衡磁盘的大小、速度、成本和其他因素,以便为工作负载提供高性能的表现 2.设计良好的数据库缓存...F.MySQL数据库即服务(DBaaS) 1.将数据库本身作为云资源 十四、应用层优化 A.常见问题 1.什么东西在消耗系统中每台主机的CPU、磁盘、网络,以及内存资源?

1.4K23

高性能 MySQL》读书笔记

READ COMMITTED(提交读),另一个事务只能读到该事务已经提交的修改,是大多数据库默认的隔离级别。...创建高性能的索引 1、B-Tree索引,其意味着所有的值都是按照顺序存储的,并且每一个叶子页到根的距离都相等。 B-Tree对索引列是顺序存储的,所以很适合查找范围数据。...3、关联查询拆成简单查询然后在应用层聚合数据,可以让缓存效率更高,单个查询可以减少锁竞争,本身查询效率也更高,在数据库中做关联查询还可能导致需要重复地访问一部分数据。...8、在很多数据库中IN等同OR,但是在mysql中,会把IN中的数据先进行排序,然后通过二分查找的方式来确定列表中的值是否满足条件,这是一个O(log n)的操作。...9、关联查询,MySQL认为任何一次查询都是一次关联,不仅仅是UNION,子查询等都可能是。

1.5K20

高性能Mysql》学习笔记(三)

高性能Mysql》学习笔记(三) 前言 接续上文继续介绍:《高性能Mysql》学习笔记(二)。...查找文本当中的「关键字」 搜索细节: 停用词 词干 复数 布尔搜索 其他索引 Toku 引擎使用的树索引 索引的优点 打打减少服务器需要扫描的数据量 帮助服务器避免排序和临时表 将随机I/O转变为顺序I/O 高性能索引策略...服务器 是否在分析大量超过需要的数据行 ❝核心:是否向数据库请求了不需要的数据 ❞ 执行查询的基础 查询状态 使用 SHOW FULL PROCESSLIST 命令 sleep Query Locked...只会在查询需要做排序操作时候为该缓存分配内存 会立即分配该参数指定的大小,而不管排序是否需要 操作系统的硬件优化 调优服务器的目标 低延时 需要高速cpu 高吞吐 同时运行很多的查询,一般可以扩展到16个或者24个 扩展多个cpu和核心 数据库并发问题...设备写入性能最高达到 480MB/S 持续写入速度可以稳定在420MB/S 每秒可以执行70000 个 4KB 的写操作 固态硬盘驱动器(SSD) X-25E驱动器 什么时候应该使用闪存 使用 flashcache 数据库下层

1.3K20
领券