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

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 【如何选择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后台线程的知识就讲到这里。当然,每个线程的具体实现细节可能因不同的版本而有所变化,这里列举出的信息仅供参考。


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
JSON Java Serverless
nacos常见问题之cpu和内存占用高如何解决
Nacos是阿里云开源的服务发现和配置管理平台,用于构建动态微服务应用架构;本汇总针对Nacos在实际应用中用户常遇到的问题进行了归纳和解答,旨在帮助开发者和运维人员高效解决使用Nacos时的各类疑难杂症。
184 0
|
1月前
|
存储 分布式计算 网络协议
阿里云服务器内存型r7、r8a、r8y实例区别参考
在阿里云目前的活动中,属于内存型实例规格的云服务器有内存型r7、内存型r8a、内存型r8y这几个实例规格,相比于活动内的经济型e、通用算力型u1实例来说,这些实例规格等性能更强,与计算型和通用型相比,它的内存更大,因此这些内存型实例规格主要适用于数据库、中间件和数据分析与挖掘,Hadoop、Spark集群等场景,本文为大家介绍内存型r7、r8a、r8y实例区别及最新活动价格,以供参考。
阿里云服务器内存型r7、r8a、r8y实例区别参考
|
6天前
|
机器学习/深度学习 缓存 监控
linux查看CPU、内存、网络、磁盘IO命令
`Linux`系统中,使用`top`命令查看CPU状态,要查看CPU详细信息,可利用`cat /proc/cpuinfo`相关命令。`free`命令用于查看内存使用情况。网络相关命令包括`ifconfig`(查看网卡状态)、`ifdown/ifup`(禁用/启用网卡)、`netstat`(列出网络连接,如`-tuln`组合)以及`nslookup`、`ping`、`telnet`、`traceroute`等。磁盘IO方面,`iostat`(如`-k -p ALL`)显示磁盘IO统计,`iotop`(如`-o -d 1`)则用于查看磁盘IO瓶颈。
|
1天前
|
Linux
Linux rsyslog占用内存CPU过高解决办法
该文档描述了`rsyslog`占用内存过高的问题及其解决方案。
18 4
|
2天前
|
Java 关系型数据库 MySQL
服务器cpu 100%解决方案
服务器cpu 100%解决方案
5 0
|
18天前
|
Linux
centos 查看服务器信息 版本cpu
centos 查看服务器信息 版本cpu
12 0
|
24天前
|
存储 缓存 NoSQL
Redis 服务器指南:高性能内存数据库的完整使用指南
Redis 服务器指南:高性能内存数据库的完整使用指南
|
27天前
|
存储 缓存 PHP
阿里云服务器实例、CPU内存、带宽、操作系统选择参考
对于使用阿里云服务器的用户来说,云服务器的选择和使用非常重要,如果实例、内存、CPU、带宽等配置选择错误,可能会影响到自己业务在云服务器上的计算性能及后期运营状况,本文为大家介绍一下阿里云服务器实例、CPU内存、带宽、操作系统的选择注意事项,以供参考。
阿里云服务器实例、CPU内存、带宽、操作系统选择参考
|
1月前
|
弹性计算 固态存储 Linux
2024年阿里云服务器租用详细价格表(CPU/内存/带宽/系统盘)
2024阿里云服务器租用优惠价格表,轻量服务器2核2G3M带宽轻量服务器一年61元,2核4G4M带宽轻量服务器一年165元12个月,ECS云服务器e系列2核2G配置、3M固定带宽、40G ESSD Entry云盘,99元一年、2核4G服务器30元3个月、2核4G配置365元一年、2核8G配置522元一年,云服务器u1、云服务器c7、g7和r7优惠价格表,CPU内存带宽系统盘配置详细报价:
818 3
|
2月前
|
弹性计算
2024阿里云幻兽帕鲁/Palworld服务器价格表(CPU/内存/带宽/磁盘收费标准)
2024年阿里云幻兽帕鲁专用服务器的价格根据不同的配置有所不同。 • 4核16G配置的价格为32元/月,如果选择购买3个月,则价格为96元。 • 8核32G配置的价格为90元/月,如果选择购买3个月,则价格为271元。 另外,还有配置为4核16G10M带宽的服务器,其价格为26元/月起。而8核32G10M带宽的价格也是90元/月。
96 1

热门文章

最新文章