读高性能MySQL(第4版)笔记04_操作系统和硬件优化

news2025/1/10 16:22:05

1. 从软件本身和它运行的典型工作负载来看,MySQL通常也更适合运行在廉价硬件上

2. 基本资源

2.1. CPU

2.2. 内存

2.3. 磁盘

2.4. 瓶颈

2.5. 网络资源

3. CPU

3.1. 最常见的瓶颈是CPU耗尽

3.2. 检查CPU使用率来确定工作负载是否受CPU限制

3.3. 低延迟(快速响应时间)

3.3.1. 需要更快的CPU,因为每个查询将只使用一个CPU

3.4. 高吞吐量

3.4.1. 如果可以同时运行多个查询,那么可以使用多个CPU为查询提供服务

4. 内存

4.1. 内存耗尽的情况也会发生,但通常只在你试图将太多内存分配给MySQL时才会发生

4.2. 配置大内存的主要原因并不是为了在内存中保存大量数据,而是为了避免磁盘I/O

4.3. 磁盘I/O比访问内存中的数据要慢几个数量级

4.4. 如果有足够的内存,可以完全避开磁盘读取操作

4.5. 如果所有数据都能装入内存,那么一旦服务器的缓存预热完成,每次读取都将是一次缓存命中

4.6. 写入可以像读取一样在内存中执行,但迟早必须被写入磁盘,才能持久保留数据

4.7. 缓存可以延迟写操作,但缓存不能像消除读操作那样消除写操作

4.8. 多次写操作,一次刷新

4.8.1. 一个数据片段可以在内存中被多次更改,而无须每一次都将新值写入磁盘

4.8.2. 当数据被最终刷新到磁盘时,自上次物理写入以来发生的所有修改都将被持久化

4.9. I/O合并

4.9.1. 许多不同的数据片段可以在内存中被修改,这些修改可以被收集在一起,因此物理写可以作为单个磁盘操作执行

4.9.2. 提前写日志(write-ahead logging)策略

4.9.2.1. 允许在内存中更改页面,而不用将更改刷新到磁盘,这通常涉及随机I/O,速度非常慢

4.9.2.2. 将更改的记录写入顺序日志文件,这样要快得多

4.9.2.3. 后台线程可以稍后将修改过的页面刷新到磁盘,这样做可以优化写操作的性能

4.10. 写操作从缓冲中获益,因为可以将随机I/O转换为顺序I/O

4.11. 异步(缓冲)写操作通常由操作系统处理,并且是被成批处理的,因此可以更优地被刷新到磁盘

4.12. 同步(无缓冲)写入必须等待数据落盘

5. 固态(闪存)存储

5.1. I/O饱和也会发生,但比CPU耗尽的频率低得多

5.2. 用HDD硬盘时,最好尝试找到一个有效的内存/磁盘比率

5.2.1. HDD延迟较高、IOPS较低

5.3. 使用SSD时,内存对磁盘的比率就变得不那么重要了

5.4. 固态设备对于提高服务器整体性能非常有用,现在通常应该成为数据库的标准配置,尤其对于OLTP工作负载

5.4.1. SSD通常比HDD快10到20倍

5.4.2. 只有在预算极为有限的系统中,或者在需要惊人的高达数PB的磁盘空间的数据仓库场景下,才考虑继续使用HDD

5.5. 比硬盘驱动器明显更好的随机读写性能

5.6. 闪存设备读的能力通常略好于写的能力

5.7. 比硬盘驱动器更好的顺序读写性能

5.8. 比硬盘驱动器更好的并发支持

5.8.1. 只有在拥有大量并发性的情况下,闪存设备才能真正实现最高吞吐量

5.9. 固态存储设备使用非易失性闪存芯片组成的单元

5.9.1. 非易失随机访问内存(NVRAM)

5.10. 固态存储建立在闪存之上

5.11. 闪存的特点

5.11.1. 可以被快速地多次读取,而且以很小的单元读取数据

5.11.2. 写入则要困难得多

5.11.2.1. 只有进行特殊的擦除操作之后,存储单元才能被重新写入数据,并且每次擦除的块大小较大

5.12. 写操作的限制是固态存储复杂性的原因

5.12.1. 为了使写操作能够很好地执行,并避免过早地耗尽闪存块写寿命,设备必须能够重新定位页面,并执行垃圾收集和所谓的损耗均衡

5.13. 为了使某些块保持新鲜并为新的写入做好准备,设备会回收块

5.14. 100GB文件在160GB的SSD上的性能与在320GB的SSD上的性能是不同的

5.14.1. 当没有空闲块时,必须等待擦除操作完成,从而导致速度减慢

5.14.2. 写入空闲块需要几百微秒,但擦除速度要慢得多,通常需要几毫秒

6. RAID

6.1. 存储引擎通常将数据/索引保存在单个大文件中,这意味着RAID通常是存储大量数据的最佳选项

6.2. 不要认为RAID是数据安全方面的强有力的保证

6.2.1. RAID并不能消除,甚至不能减少备份的需要

6.3. 保存在损坏的物理媒介中的数据很少被访问,可能几个月都不会被发现,直到尝试读取数据,或者当另一个驱动器出现故障,RAID控制器尝试使用损坏的数据重建阵列时才发现问题

6.3.1. 硬盘空间越大,出现这种情况的可能性就越大

6.4. 大多数控制器都提供了一些软件来报告阵列的状态,你需要对此进行跟踪,否则可能完全不知道驱动器已出现故障

6.4.1. 到第二个驱动器出现故障时就太晚了

6.5. 通过定期主动检查阵列的一致性,可以降低潜在的损坏风险

6.6. 很多RAID控制器不能很好地处理大数据块

6.7. RAID缓存是物理安装在硬件RAID控制器上的(相对)少量内存

6.7.1. 在RAID缓存中缓存读取都是浪费内存

6.8. RAID控制器的内存是一种稀缺资源,应该明智地使用它

6.9. 对事务日志发出fsync()调用,并在启用sync_binlog的情况下创建二进制日志,但除非控制器有备用电池单元(BBU)或其他非易失性存储,否则不应启用写缓存

6.9.1. 硬盘也可能会撒谎。应该确保在fsync()时刷新缓存,或者干脆在没有备用电池时禁用它们

6.9.2. 当安装新硬件时,最好进行真正的暴力碰撞测试(例如把电源插头拔出来)。这通常是发现细微的错误配置或偷偷摸摸的硬盘行为的唯一方法

6.10. 要测试RAID控制器的BBU是否真的可靠,请确保将电源线拔下一段时间

6.10.1. 有些BBU设备在没电的情况下无法维持足够的时间(将RAID缓存的数据刷新到磁盘

6.10.2. 一个环节出问题可能会导致整个存储系统链变得无用

6.11. RAID 0

6.11.1. 最便宜和性能最好的RAID配置

6.11.2. 永远不适合用于生产数据库

6.11.3. 在开发环境中,当服务器完全失效也不会变成突发事件时,可以选择RAID 0

6.11.4. 不提供任何冗余

6.11.5. RAID 0阵列的故障概率高于任何单磁盘的故障概率,而不是更低

6.12. RAID 1

6.12.1. 良好的读性能,并且可以跨磁盘复制数据

6.12.2. 良好的冗余

6.12.3. 读取速度略高于RAID 0

6.12.4. 顺序写入不需要许多底层磁盘就能执行得很好

6.12.5. 需要冗余但只有两个硬盘驱动器的低端服务器的典型选择

6.12.6. 大多数操作系统都允许你轻松地创建软件RAID 0和RAID 1卷

6.13. RAID 5

6.13.1. 将数据分布在具有分布式奇偶校验块的多块磁盘上,以便在任何一块磁盘出现故障时,可以从奇偶校验块重建数据

6.13.2. 如果两块磁盘同时出现故障,整个卷将无法恢复

6.13.2.1. 丢失两块磁盘时会产生灾难性的后果

6.13.3. RAID 5的可伸缩性不能超过10块磁盘

6.13.4. 良好的RAID 5的性能在很大程度上依赖于RAID控制器的缓存,这可能与数据库服务器的需求相冲突

6.14. RAID 6

6.14.1. 允许你在承受两次磁盘故障的情况下仍然能重建阵列

6.14.2. 计算额外的奇偶校验会使写操作比RAID 5慢

6.15. RAID 10

6.15.1. 一个非常好的数据存储选择

6.15.2. 条带化的镜像对组成,因此在读写方面都能很好地被扩展

6.15.2.1. 最佳的条带块大小取决于工作负载和硬件

6.15.2.2. 对于随机I/O来说,拥有较大的块大小是很好的,因为这意味着可以从单个驱动器中满足更多的读取需求

6.15.3. 与RAID 5相比,它的重建速度快且容易

6.15.4. 以很好地在软件中被实现

6.16. RAID 50

6.16.1. 由条带化的RAID 5阵列组成,如果有很多磁盘,它可以很好地兼顾RAID 5的经济性和RAID 10的性能

6.16.2. 主要用于非常大的数据集,如数据仓库或非常大的OLTP系统

7. 网络

7.1. 延迟和带宽是网络连接的限制因素

7.2. 网络运行不正常是主要的性能瓶颈

7.3. 数据包丢失是一个常见的问题

7.3.1. 即使是1%的丢失也足以导致性能显著下降,因为协议栈中的各个层都会尝试通过等待一段时间然后重新发送数据包等策略来解决问题,这会增加额外的响应时间

7.4. DNS解析异常中断或缓慢成为一个致命弱点

7.4.1. 对于生产服务器来说,启用skip_name_resolve是一个好主意

7.4.2. 当MySQL收到连接请求时,它会同时进行正向和反向DNS查找

7.4.3. 如果启用skip_name_resolve选项,MySQL不会进行任何DNS查找

7.4.3.1. 意味着用户账号在host列中只能有IP地址、“localhost”或IP地址通配符

7.4.3.2. host列中包含主机名的任何用户账号都将无法登录

8. 文件系统

8.1. 文件系统是在数据库中保证数据完整性的最低层

8.2. Windows

8.2.1. 只有一个(NTFS)是真正可行的

8.3. GNU/Linux

8.3.1. 大多数时候,给定的文件系统跟其他文件系统相比不会有明显的差别

8.3.2. 只有在某些情况下,达到文件系统的处理极限时,例如,需要处理高并发性、处理许多文件、碎片,等等,不同文件系统的差异才会体现出来

8.3.3. 最好使用日志型文件系统,如ext4、XFS或ZFS

8.3.4. 建议使用XFS文件系统,并将交换率和磁盘队列调度器设置为适合于服务器的值

8.4. 磁盘队列调度器

8.4.1. 完全公平排队,即CFQ(Complete FairQueuing)

8.4.2. 在MySQL的工作负载类型下,CFQ会导致非常糟糕的响应时间,因为会不必要地阻塞队列中的一些请求

8.4.3. 不要使用CFQ,它可能会导致严重的性能问题

8.5. 内存和交换

8.5.1. 给MySQL分配大量内存后,它的表现最好

8.5.2. InnoDB使用内存作为缓存来避免磁盘访问

8.5.2.1. 意味着内存系统的性能会直接影响查询的速度

8.5.3. 当使用SSD时,性能损失不像使用HDD时那样明显

8.5.3.1. 仍然应该积极地避免交换,即使只是为了避免不必要的写操作,因为写操作可能会缩短磁盘整体寿命

8.5.4. 更改存储引擎读写数据的方式

8.5.4.1. 设置innodb_flush_method=O_DIRECT可以减轻I/O压力

8.5.4.2. 该参数仅对InnoDB有效

8.6. 很多技巧都是特定于内核版本的,所以要小心,特别是在升级时

8.7. Linux剖析器perf是一个非常有用的工具,可以用它来检查操作在系统级别发生的事情

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/987148.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JavaScipt中如何实现函数缓存?函数缓存有哪些场景?

1、函数缓存是什么? 函数缓存就是将函数运行的结果进行缓存。本质上就是用空间(缓存存储)换时间(计算过程) 常用于缓存数据计算结果和缓存对象。 缓存只是一个临时的数据存储,它保存数据,以便将…

异步编程 - 09 Spring框架中的异步执行_@Async注解异步执行原理源码解析

文章目录 概述小结好文推荐 概述 在Spring中调用线程将在调用含有Async注释的方法时立即返回,Spring是如何做到的呢?其实是其对标注Async注解的类做了代理,比如下面的类Async-AnnotationExample。 public class AsyncAnnotationExample {As…

Qt 5.15集成Crypto++ 8.8.0(MSVC 2019)笔记

一、背景 笔者已介绍过在Qt 5.15.x中使用MinGW(8.10版本)编译并集成Crypto 8.8.0。 但是该编译出来的库(.a和.dll)不适用MSVC(2019版本)构建环境,需要重新编译(.lib或和.dll&#xf…

C++11新特性② | 左值、左值引用、右值与右值引用

目录 1、引言 2、值类别及相关概念 3、左值、右值 4、左值引用、右值引用 5、移动语义 5.1、为什么需要移动语义 5.2、移动语义定义 5.3、转移构造函数 5.4、转移赋值函数 6、标准库函数 std::move 7、完美转发 std::forward VC常用功能开发汇总(专栏文章…

Mybatis 使用typeHandler自定义类型转换

之前我们介绍了使用Mybatis完成数据的增删改查操作;本篇我们介绍使用Mybatis提供的typeHandler自定义类型转换。 如果您对Mybatis的增删改查操作不太了解,可以参考: Mybatis 查询数据https://blog.csdn.net/m1729339749/article/details/13…

explain 实战-----查看hive sql执行计划

目录 1.join/left join/full join 语句会过滤关联字段 null 的值吗? (1)join (2) left join /full join 2.group by 分组语句会进行排序吗? 1.join/left join/full join 语句会过滤关联字段 null 的值吗…

Qt 5.15编译(MinGW)及集成Crypto++ 8.8.0笔记

一、背景 为使用AES加密库(AES/CBC加解密),选用Crypto 库(官网)。   最新Crypto C库依次为:8.8.0版本(2023-6-25)、8.7.0(2022-8-7)和8.6.0(202…

绘图系统三:支持散点图、极坐标和子图绘制

文章目录 新增散点图绘制绑定与回调极坐标功能子图绘制功能源代码 📈一 三维绘图系统📈二 多图绘制系统 新增散点图绘制 同一坐标系中绘制多个图像是很常见的需求,比如数据拟合的时候,用散点图表示原始数据,用曲线图…

vue3 webpack打包流程及安装 (1)

npm run build 也可以打包 如果没有特殊需求 可以使用 效果其实是差不多的 --------------------------------------------------------------------------------------------------------------------------------- webpack网址 : 起步 | webpack 中文文档 (docsc…

记录docker 部署nessus

1、开启容器 docker run -itd --nameramisec_nessus -p 8834:8834 ramisec/nessus 2、登录 :注意是https https://ip8843 3、修改admin密码 #进入容器 docker exec -it ramisec_nessus /bin/bash#列出用户名 /opt/nessus/sbin/nessuscli lsuser#修改密码&a…

(html+CSS)垂直居中

line-height 设置文字行高等于父元素的高度 vertical-align 用于设置一个元素的垂直对齐方式,但是它只针对于行内元素或者行内块元素有效。 属性值说明baseline默认,元素放置在父元素的基线上top把元素的顶端与行中最高元素的顶端对齐middle把此元素…

递归算法学习——黄金矿工,不同路径III

目录 ​编辑 一,黄金矿工 1.题意 2.题目分析 3.题目接口 4.解题思路及代码 二,不同路径III 1.题意 2.解释 3.题目接口 4.解题思路及代码 一,黄金矿工 1.题意 你要开发一座金矿,地质勘测学家已经探明了这座金矿中的资源…

YMatrix 5.0 与天翼云完成产品兼容性认证

近日,北京四维纵横数据技术有限公司与天翼云宣布完成产品兼容性认证。经过双方严格的测试验证,超融合数据库 YMatrix 5.0 与天翼云兼容性良好,可基于天翼云稳定运行。 数据库系统作为基础软件的核心,自主可控势在必行。在此背景下…

项目(智慧教室)第一部分:cubemx配置,工程文件的移植,触摸屏的检测,项目bug说明

第一章:需求与配置 一。项目需求 二。实现外设控制 注意: 先配置引脚,再配置外设。否则会出现一些不可预料的问题 1.时钟,串口,灯,蜂鸣器配置 (1)RCC配置为外部时钟,修…

Android 开发小贴士

Android 开发小贴士 Unable to merge dex 原因: 1. 包引用重复 2. 方法数超限 3. 或者几个库之间有重复代码块(特别是在整理module时容易犯) 解决: 1. app的build.gradle中 // 1. 添加配置 defaultConfig {......multiDexEnabled true }// 2. 清除缓…

pico学习进程记录已经开发项目

Pico pin脚定义 Pico 运行准备 下载uf2文件 https://pico.org.cn/ (注意运行micropython的文件和运行c/c的不一样) 装载uf2文件:按住pico的按键,然后通过micro usb连接电脑(注意:如果用的线材,…

菜鸟教程《Python 3 教程》笔记(19):错误与异常

菜鸟教程《Python 3 教程》笔记(19) 19 错误和异常19.1 assert(断言)19.2 异常处理19.2.1 try/except19.2.2 try/except...else19.2.3 try-finally 语句 19.3 抛出异常19.4 用户自定义异常19.5 清理行为19.5.1 定义清理行为19.5.2…

生信分析Python实战练习 6 | 视频24

开源生信 Python教程 生信专用简明 Python 文字和视频教程 源码在:https://github.com/Tong-Chen/Bioinfo_course_python 目录 背景介绍 编程开篇为什么学习Python如何安装Python如何运行Python命令和脚本使用什么编辑器写Python脚本Python程序事例Python基本语法 数…

HTTP代理协议原理分析

HTTP代理协议是一种常见的网络协议,它可以在网络中传递HTTP协议的请求和响应。本文将介绍HTTP代理协议的分析和原理,包括HTTP代理的工作流程、HTTP代理的请求和响应格式、HTTP代理的优缺点等方面。 一、HTTP代理的工作流程 HTTP代理的工作流程如下&#…

OmniGraffle Pro for Mac 中文正式版(附注册码) 苹果电脑 思维导图软件

OmniGraffle Pro是OmniGraffle的高级版本,它提供了更多的功能和工具,可以帮助用户创建更为复杂和高级的图表和流程图。OmniGraffle Pro支持自定义形状、图形、线条和箭头等,可以让用户创建出更加精细的图表。此外,OmniGraffle Pro…