当前位置: 首页 > news >正文

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

文章目录

  • 🔊博主介绍
  • 🥤本文内容
  • 📢文章总结
  • 📥博主目标

🔊博主介绍

🌟我是廖志伟,一名Java开发工程师、Java领域优质创作者、CSDN博客专家、51CTO专家博主、阿里云专家博主、清华大学出版社签约作者、产品软文专业写手、技术文章评审老师、问卷调查设计师、个人社区创始人、开源项目贡献者。🌎跑过十五公里、🚀徒步爬过衡山、🔥有过三个月减肥20斤的经历、是个喜欢躺平的狠人。

📕拥有多年一线研发和团队管理经验,研究过主流框架的底层源码(Spring、SpringBoot、Spring MVC、SpringCould、Mybatis、Dubbo、Zookeeper),消息中间件底层架构原理(RabbitMQ、RockerMQ、Kafka)、Redis缓存、MySQL关系型数据库、 ElasticSearch全文搜索、MongoDB非关系型数据库、Apache ShardingSphere分库分表读写分离、设计模式、领域驱动DDD、Kubernetes容器编排等。

📙有过从0到1的项目高并发项目开发与管理经验,对JVM调优、MySQL调优、Redis调优 、ElasticSearch调优、消息中间件调优、系统架构调优都有着比较全面的实战经验。

📘有过云端搭建服务器环境,自动化部署CI/CD,弹性伸缩扩容服务器(最高200台),了解过秒级部署(阿里云的ACK和华为云的云容器引擎CCE)流程,能独立开发和部署整个后端服务,有过分库分表的实战经验。

🎥经过多年在CSDN创作上千篇文章的经验积累,我已经拥有了不错的写作技巧,与清华大学出版社签下了四本书籍的合约,并将陆续在明年出版。这些书籍包括了基础篇、进阶篇、架构篇的📌《Java项目实战—深入理解大型互联网企业通用技术》📌,以及📚《解密程序员的思维密码–沟通、演讲、思考的实践》📚。具体出版计划会根据实际情况进行调整,希望各位读者朋友能够多多支持!


文章目录

  • 🔊博主介绍
  • 🥤本文内容
  • 📢文章总结
  • 📥博主目标

🌾阅读前,快速浏览目录和章节概览可帮助了解文章结构、内容和作者的重点。了解自己希望从中获得什么样的知识或经验是非常重要的。建议在阅读时做笔记、思考问题、自我提问,以加深理解和吸收知识。

💡在这个美好的时刻,本人不再啰嗦废话,现在毫不拖延地进入文章所要讨论的主题。接下来,我将为大家呈现正文内容。

🥤本文内容

CSDN

今天我们就来深入探讨一下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后台线程的知识就讲到这里。当然,每个线程的具体实现细节可能因不同的版本而有所变化,这里列举出的信息仅供参考。

CSDN

📢文章总结

对本篇文章进行总结:

🔔以上就是今天要讲的内容,阅读结束后,反思和总结所学内容,并尝试应用到现实中,有助于深化理解和应用知识。与朋友或同事分享所读内容,讨论细节并获得反馈,也有助于加深对知识的理解和吸收。

以梦为马,不负韶华

🔔如果您需要转载或者搬运这篇文章的话,非常欢迎您私信我哦~

🚀🎉希望各位读者大大多多支持用心写文章的博主,现在时代变了,🚀🎉 信息爆炸,酒香也怕巷子深🔥,博主真的需要大家的帮助才能在这片海洋中继续发光发热🎨,所以,🏃💨赶紧动动你的小手,点波关注❤️,点波赞👍,点波收藏⭐,甚至点波评论✍️,都是对博主最好的支持和鼓励!

  • 💂 博客主页: 我是廖志伟
  • 👉开源项目:java_wxid
  • 🌥 哔哩哔哩:我是廖志伟
  • 🎏个人社区:幕后大佬
  • 🔖个人微信号SeniorRD
  • 🎉微信号二维码SeniorRD

📥博主目标

探寻内心世界,博主分享人生感悟与未来目标

  • 🍋程序开发这条路不能停,停下来容易被淘汰掉,吃不了自律的苦,就要受平庸的罪,持续的能力才能带来持续的自信。我本是一个很普通的程序员,放在人堆里,除了与生俱来的盛世美颜,就剩180的大高个了,就是我这样的一个人,默默写博文也有好多年了。
  • 📺有句老话说的好,牛逼之前都是傻逼式的坚持,希望自己可以通过大量的作品、时间的积累、个人魅力、运气、时机,可以打造属于自己的技术影响力。
  • 💥内心起伏不定,我时而激动,时而沉思。我希望自己能成为一个综合性人才,具备技术、业务和管理方面的精湛技能。我想成为产品架构路线的总设计师,团队的指挥者,技术团队的中流砥柱,企业战略和资本规划的实战专家。
  • 🎉这个目标的实现需要不懈的努力和持续的成长,但我必须努力追求。因为我知道,只有成为这样的人才,我才能在职业生涯中不断前进并为企业的发展带来真正的价值。在这个不断变化的时代,我们必须随时准备好迎接挑战,不断学习和探索新的领域,才能不断地向前推进。我坚信,只要我不断努力,我一定会达到自己的目标。

🔔有需要对自己进行综合性评估,进行职业方向规划,我可以让技术大牛帮你模拟面试、针对性的指导、传授面试技巧、简历优化、进行技术问题答疑等服务。

可访问:https://java_wxid.gitee.io/tojson/

开发人员简历优化、面试突击指导、技术问题解答

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Linux学习第49天:Linux块设备驱动实验(一):Linux三大驱动之一
  • 硬件安全模块 (HSM)、硬件安全引擎 (HSE) 和安全硬件扩展 (SHE)的区别
  • 四十八----react实战
  • IO进程线程 day1 IO基础+标准IO
  • 爬虫工作量由小到大的思维转变---<第三十章 Scrapy Redis 第一步(配置同步redis)>
  • UntiyShader(六)Unity提供的Cg/HLSL语义
  • AI提示词入门教程
  • idea中终端Terminal页面输入命令git log后如何退出
  • 第一章 简单编程实现花生壳的ddns功能
  • Redis7.2.3(Windows版本)
  • English: go through customs
  • vue3为什么使用带有 .value 的 ref,而不是普通的变量
  • Pytorch的讲解及实战·MNIST数据集手写数字识别
  • Android 8.1 设置USB传输文件模式(MTP)
  • gitee+picgo+typora图床搭建
  • angular2开源库收集
  • css的样式优先级
  • es6--symbol
  • JS实现简单的MVC模式开发小游戏
  • Koa2 之文件上传下载
  • leetcode46 Permutation 排列组合
  • Map集合、散列表、红黑树介绍
  • Promise面试题2实现异步串行执行
  • Python语法速览与机器学习开发环境搭建
  • STAR法则
  • Swoft 源码剖析 - 代码自动更新机制
  • underscore源码剖析之整体架构
  • Vue 重置组件到初始状态
  • vue-cli在webpack的配置文件探究
  • -- 查询加强-- 使用如何where子句进行筛选,% _ like的使用
  • 纯 javascript 半自动式下滑一定高度,导航栏固定
  • 简单实现一个textarea自适应高度
  • 解析带emoji和链接的聊天系统消息
  • 目录与文件属性:编写ls
  • 思维导图—你不知道的JavaScript中卷
  • 算法系列——算法入门之递归分而治之思想的实现
  • 我感觉这是史上最牛的防sql注入方法类
  • 一文看透浏览器架构
  • ​Linux Ubuntu环境下使用docker构建spark运行环境(超级详细)
  • #laravel部署安装报错loadFactoriesFrom是undefined method #
  • #我与Java虚拟机的故事#连载09:面试大厂逃不过的JVM
  • %@ page import=%的用法
  • (01)ORB-SLAM2源码无死角解析-(56) 闭环线程→计算Sim3:理论推导(1)求解s,t
  • (2020)Java后端开发----(面试题和笔试题)
  • (Java实习生)每日10道面试题打卡——JavaWeb篇
  • (Matlab)使用竞争神经网络实现数据聚类
  • (Note)C++中的继承方式
  • (笔试题)合法字符串
  • (待修改)PyG安装步骤
  • (解决办法)ASP.NET导出Excel,打开时提示“您尝试打开文件'XXX.xls'的格式与文件扩展名指定文件不一致
  • (六)Flink 窗口计算
  • (论文阅读笔记)Network planning with deep reinforcement learning
  • (亲测有效)解决windows11无法使用1500000波特率的问题
  • (算法二)滑动窗口
  • (转)EXC_BREAKPOINT僵尸错误