【如何选择Mysql服务器的CPU核数及内存大小】

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 【如何选择Mysql服务器的CPU核数及内存大小】



今天我们就来深入探讨一下MySQL后台线程的那些事儿。你知道吗,MySQL后台线程不仅仅是为了维持系统运转那么简单,它们还肩负着备份数据、确保缓存最新,以及保障磁盘访问安全等等重要任务呢!以下我要分享的观点,都是我在研读《MySQL技术内幕:InnoDB存储引擎》时的心得体会。


首先,要想了解MySQL后台线程,我们先得从“马主人”线程MasterThread说起。要说这个线程可真是挺关键的,它负责把缓冲池里的数据备份到硬盘上,来保持数据的一致性,像更新脏页面呀,合并插入缓冲啊,回收UNDO页面什么的,都是靠它搞定的。而且值得一提的是,从1.1版开始,这项操作就可以独立出来了。哈哈,看来这个Life Cycle解析得好清楚喔!


另外,还有几个我们不能忽视的后台线程:IO线程IOD(Input/Output thread)、清理线程PurgeThread和清洁线程PageCleanerThread。别看他们听起来神秘莫测,其实他们在提升数据库性能方面可是功不可没哟。在这里,强烈推荐大家去学习一下那四类IO线程(write、read、insert buffer和log IO thread)。

更有趣儿的是,IO线程是用大量的AIO(Async IO)来应对写入IO请求(write、read、insert buffer和IOP thread)的哦,简直就是性能的救星!而且IOD线程的主要任务就是处理这些IO请求的回调。至于PurgeThread嘛,它主要是帮助处理在事务提交后,曾经引用过的undo log(回滚日志)并不再需要的情形,此时就要用到PurgeThread来回收已使用且分配过的undo页面啦。而PageCleanerThread,大家记住是从InnoDB的1.2.x版更新的东东,专门负责将过去版本中的更新脏页面操作放在单独的线程里执行,从而减轻了"马主人"线程的负担。


说到线程配置,让我们假设一下有个16个核的服务器,MySQL给你分派了这么几条线程:"马主人"线程1条,IORef线程13条(为了维护平衡,让read thread和write thread都各占6个核),PurgeThread和PageCleanerThread各1条。不过要注意的是,有些版本的mysql还需要InsertBuffer线程,但到了 MySQL 5.6和更高版本就不用操心了。同样地,LogIOT线程在某些版本中还是必要的,但是到了 MySQL 5.7以上的版本就可以放手不管了。


如果要深入研究的话,你会发现主线程MasterThread享有最高的优先权。在它的内部,包含了多个循环过程:主要循环过程、后台循环过程、清空循环过程和停止循环过程。主线程会根据数据库运行状况在各个循环过程中轮流更换。这就是MySQL内部线程的运作方式。


现在让我们回到线程切换:MasterThread -> background loop(可能跳转到flush loop) -> flush loop -> suspend loop,这里,MasterThread会暂时休眠一下,等待些什么事情发生。好啦,关于MySQL后台线程的知识就讲到这里。当然,每个线程的具体实现细节可能因不同的版本而有所变化,这里列举出的信息仅供参考。


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4天前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
89 1
|
29天前
|
缓存 监控 关系型数据库
如何查看MySQL使用的内存
如何查看MySQL使用的内存
96 1
|
29天前
|
存储 缓存 监控
深入了解MySQL内存管理:如何查看MySQL使用的内存
深入了解MySQL内存管理:如何查看MySQL使用的内存
200 1
|
2月前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
110 5
|
19天前
|
SQL 监控 关系型数据库
如何查看MySQL使用的内存
综合运用上述方法,您可以全方位地监控和管理MySQL的内存使用。从简单查看配置到深入分析实时内存占用,每种方法都有其适用场景和优势。定期检查和调整MySQL的内存配置,对于维持数据库性能和稳定性至关重要。
71 0
|
26天前
|
C# 开发工具 Windows
C# 获取Windows系统信息以及CPU、内存和磁盘使用情况
C# 获取Windows系统信息以及CPU、内存和磁盘使用情况
38 0
|
2月前
|
Prometheus Kubernetes 监控
使用kubectl快速查看各个节点的CPU和内存占用量
在Kubernetes集群中,安装metrics-server,并使用kubectl快速查看集群中各个节点的资源使用情况。
93 0
|
3月前
|
存储 监控 Docker
如何限制docker使用的cpu,内存,存储
如何限制docker使用的cpu,内存,存储
|
3月前
|
算法 Windows
CAE如何基于CPU最佳核数和token等计算成本
【8月更文挑战第26天】在使用CAE(计算机辅助工程)进行分析计算时,需综合考虑CPU核数和token对成本的影响。CPU核数越多,虽能加速计算,但过多核数会因通信开销和内存带宽限制导致性能提升放缓。成本计算需考虑硬件租赁或购买费用及云服务收费标准。Token作为软件许可,需分摊到每次计算中。通过测试优化找到性能与成本的平衡点,实现最低成本下的高效计算。
|
3月前
|
SQL 存储 关系型数据库
实时计算 Flink版产品使用问题之同步MySQL多张表的过程中,内存释放依赖于什么
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。

推荐镜像

更多