第二轮:从 Linux 内核事件看 MySQL 性能瓶颈

经过两次优化后,mysql 的单个连接 tps 如下:

优化前 第一轮 第二轮

158 tps1673 tps1924 tps

通过第二轮优化,性能提升到了原来的 12.18 倍(1924 / 158 ≈ 12.18)。接下来我们详细探讨这两次优化的过程。

书接上回

上次我们通过 Linux 内核的 ebpf 模块的观测能力,成功定位了 MySQL 的瓶颈,并通过调整相应的 MySQL 参数,将 tps 从 158 提升到了 1673。然而,从性能角度来看,我们仍有提升空间。

我们继续按照既定方法论,先从整体上把握 Linux 的资源使用情况。

mpstat 1 30Linux 5.14.0-55.el9.x86_64 (git-sqlpy-com)   07/21/2022   _x86_64_  (2 CPU)01:30:15 AM  CPU    %usr   %nice    %sys %iowait    %irq   %soft  %steal  %guest  %gnice   %idle01:30:16 AM  all   37.63    0.00    7.73   11.86    0.00    3.09    0.00    0.00    0.00   39.6901:30:17 AM  all   38.38    0.00    7.07   14.65    0.00    3.03    0.00    0.00    0.00   36.8701:30:18 AM  all   38.34    0.00    7.77   12.44    0.00    3.11    0.00    0.00    0.00   38.3401:30:19 AM  all   36.04    0.00    6.09   13.20    0.00    3.05    0.00    0.00    0.00   41.62

可以看出,IO-WAIT 仅有 10% 左右,说明 IO 负载并不高;但 CPU 的用户态使用率接近 40%,这相对于 IO 来说较高,整体资源使用并不均衡。

分析问题

从上次优化后的资源使用情况(IO-WAIT 较低)可以得出,如果有必要,我们可以通过增加 IO 资源来降低 CPU 资源的使用(IO 为 10%,CPU 为 40%)。当然,最终是否有必要还需数据支持。幸运的是,上次优化后的火焰图仍然可用,它可以提供我们所需的数据。

第二轮:从 Linux 内核事件看 MySQL 性能瓶颈

binlog_cache_data::compress 这个压缩 BIN-LOG 的函数占用了 10.28% 的 CPU 资源。考虑到 BIN-LOG 是顺序 IO,且目前 IO 不是瓶颈,为了节省 CPU 资源,我们决定“优化”掉压缩功能。这样,我们打算通过增加 IO 资源来换取 CPU 资源,从而打造一个更加均衡的系统。

调整参数验证性能

由于我们的目标是提升性能,压缩 BIN-LOG 在此目标下是没有意义的。因此,我们调整 MySQL 参数,关闭 BIN-LOG 压缩,避免 CPU 执行无意义的任务。

mysql> set @@global.binlog_transaction_compression = OFF;Query OK, 0 rows affected (0.00 sec)

接下来,我们测试性能:

mtls-auto-fill --host=127.0.0.1 --port=3306 --user=root --password=xxx --database=tempdb --table=t --rows=50000 executeReport:------------------------------------|tps = 1924.565426390742|cost_time = 25.979891------------------------------------Compelete.

然后,我们绘制火焰图以查看优化后的效果:

宣小二 宣小二

宣小二:媒体发稿平台,自媒体发稿平台,短视频矩阵发布平台,基于AI驱动的企业自助式投放平台。

宣小二 21 查看详情 宣小二

# 这里直接用的 ebpf 生态的工具profile  -p 537985 -af 11 --stack-storage-size=163840 > /tmp/simple-insert-double-zero-binlog-not-compression.out

第二轮:从 Linux 内核事件看 MySQL 性能瓶颈

trans_commit 原本是一个双峰结构,右边的峰是由于压缩 BIN-LOG 导致的,占用约 10.28% 的 CPU。经过我们的参数调整,这部分消耗已被消除。

此外,最左边的 syscall 峰也消失了(目前还无法确定其具体作用,但以后会进一步分析),它在未优化前大约占用 5% 的 CPU。

根据这两组数据,我们可以从火焰图大致推算出 CPU 优化的收益。一个是 10%,另一个是 5%,总的性能大致提升了 115%。我们现在可以估算性能提升:

In [1]: 1673 * 1.15Out[1]: 1923.949

我们的实测值为 1924.565,与估算值非常接近。

还有没有油水

关于是否还有进一步优化的空间,我们可以通过观察系统资源使用情况来判断。

mpstat 1 30Linux 5.14.0-55.el9.x86_64 (git-sqlpy-com)   07/29/2022   _x86_64_  (2 CPU)00:42:06 AM  CPU    %usr   %nice    %sys %iowait    %irq   %soft  %steal  %guest  %gnice   %idle00:42:07 AM  all   32.16    0.00    9.55   17.59    0.00    3.02    0.00    0.00    0.00   37.6900:42:08 AM  all   34.54    0.00   10.31   18.04    0.00    3.09    0.00    0.00    0.00   34.0200:42:09 AM  all   36.18    0.00    8.54   18.59    0.00    3.52    0.00    0.00    0.00   33.1700:42:10 AM  all   34.85    0.00    9.60   19.70    0.00    2.53    0.00    0.00    0.00   33.3300:42:11 AM  all   33.85    0.00    9.74   21.54    0.00    4.10    0.00    0.00    0.00   30.77

可以看到,参数调整后,用户态 CPU 使用率从之前的 40% 左右下降到了 34% 左右,而 IO-WAIT 从 10% 左右上升到了 20%。也就是说,整个系统从 40:10 的结构调整到了 34:20 的结构,变得更加均衡。

我们再来看一下 IO-WAIT 上升 100% 的原因(从 10% 上升到 20%,上升了 100%)。

funccount -i 1 -p 111659 'vfs_*'FUNC                                    COUNTb'vfs_fsync_range'                        496b'vfs_write'                             6159b'vfs_read'                              8373

可以看到,sync 和 write 的比例关系发生了变化,由之前的 292:7009 变成了现在的 496:6159

因此,还有优化的空间,请分享这篇文章,说不定更新速度会更快哦!

以上就是第二轮:从 Linux 内核事件看 MySQL 性能瓶颈的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/456912.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 01:49:27
下一篇 2025年11月8日 01:50:19

相关推荐

  • NFT空投埋伏指南 Pudgy后下一个是谁

    本文将为您提供一份详尽的链上数据分析指南,帮助您掌握识别潜在早期机会的方法。我们将详细讲解如何一步步进行链上数据挖掘,从而更好地把握NFT市场的未来趋势。 2025主流加密货币交易所官网注册地址推荐: 欧易OKX: Binance币安: Gateio芝麻开门: 火币htx:[ 理解链上数据分析的重要…

    2025年12月8日
    000
  • 以太坊L2交易量破纪录!Layer3时代来临 埋伏这7个尚未发车的生态项目早期红利

    本文将探讨L2交易量创纪录的现象,解析Layer 3(L3)时代的到来及其潜在机遇。同时提供一些关于如何识别和参与早期生态项目的思路和方法,帮助读者更好地理解当前的市场动态。 2025主流加密货币交易所官网注册地址推荐: 欧易OKX: Binance币安: Gateio芝麻开门: 火币htx:[ L…

    2025年12月8日
    000
  • 2025欧易交易所官方app 欧易安卓最新版v6.127.0

    欧易(OKX)是一款在全球范围内广受欢迎的数字资产服务平台,为用户提供多样化的数字资产交易选项、金融服务以及先进的交易工具,凭借其安全稳定的系统和友好的用户界面,赢得了众多用户的信赖。为了帮助您顺利开始使用,本文将提供欧易官方app的下载与安装全流程指南。点击本文中提供的官方下载链接,即可安全、快速…

    2025年12月8日
    000
  • 币安APP最新版 2025币安官方正版安装

    币安APP是一款全球领先的数字资产交易平台,提供包括比特币、以太坊等在内的多种加密货币的交易服务,以及丰富的金融产品和专业的市场分析工具。我们推荐您点击本文提供的下载链接来获取官方APP,这能确保您下载到的是最新、最安全的版本。 币安官网: 币安APP下载与安装教程 以下是下载和安装币安APP的详细…

    2025年12月8日
    000
  • 全网爆仓榜TOP10最新数据 暴跌行情下如何逆势盈利

    本文将围绕“全网爆仓榜TOP10最新数据”以及“暴跌行情下如何逆势盈利”这两个主题展开阐述。针对标题中的潜在问题,本文将结合当前市场行情,通过提供清晰的步骤和操作建议来解答,帮助读者理解在市场下跌时进行交易的策略和方法,并探讨一些可能实现逆势盈利的途径。 2025主流加密货币交易所官网注册地址推荐:…

    2025年12月8日
    000
  • 百万仓位1分钟归零 揭秘交易所不告诉你的风控秘籍

    本文将围绕“百万仓位1分钟归零:揭秘交易所不告诉你的风控秘籍”这一主题展开阐述。重点解释为何会出现这种情况,并深入揭秘交易所可能不会主动强调的风控策略,帮助读者理解并学习如何在交易中保护自己的资本。 2025主流加密货币交易所官网注册地址推荐: 欧易OKX: Binance币安: Gateio芝麻开…

    2025年12月8日
    000
  • 币圈空投暴富指南 2025最新羊毛清单

    空投并非绝对的暴富捷径,更多的是一种参与区块链项目、获取潜在收益的途径。本文将聚焦于如何高效参与空投项目,并提供可操作的指导,帮助读者了解参与流程,最大化潜在收益。 2025主流加密货币交易所官网注册地址推荐: 欧易OKX: Binance币安: Gateio芝麻开门: 火币htx:[ 理解空投与风…

    2025年12月8日
    000
  • 空投埋伏黄金期!这些项目即将发币 错过ARKM别再错过这3个潜力协议

    当前是参与空投的有利时机,本文将围绕如何识别和参与潜在的空投项目展开阐述,发现潜在高价值空投项目,并介绍一些当前备受关注的潜力协议,帮助您把握这一“黄金期”。 2025主流加密货币交易所官网注册地址推荐: 欧易OKX: Binance币安: Gateio芝麻开门: 火币htx:[ 把握空投黄金期:如…

    2025年12月8日
    000
  • 空投套利秘籍!如何用1U博取100倍 资深猎人不说的多账号矩阵玩法

    文章旨在揭示低成本参与加密货币空投并实现高额回报的策略,以及如何通过多账号矩阵来放大收益。我们将深入探讨操作步骤,帮助读者理解其中的关键技巧。 2025主流加密货币交易所官网注册地址推荐: 欧易OKX: Binance币安: Gateio芝麻开门: 火币htx:[ 空投套利的策略解析 在加密货币领域…

    2025年12月8日
    000
  • 币价暴跌时合约怎么操作?如何反向开单?

    加密货币市场价格波动剧烈,币价经历大幅下跌是常见现象。在现货市场中,价格下跌意味着资产价值缩水。然而,合约交易提供了一种在价格下跌趋势中寻找机会的方式。利用合约工具,交易者可以在市场下跌时进行一些操作,与单纯持有现货不同。 进行合约交易,了解其机制非常重要。合约允许交易者使用杠杆,这会放大潜在的收益…

    2025年12月8日
    000
  • 比特币合约爆仓预警怎么设置?如何避免强制平仓?

    比特币合约交易吸引了众多参与者,它提供利用杠杆进行潜在高回报的机会。然而,合约交易的固有风险在于强制平仓,俗称“爆仓”。爆仓意味着交易者的仓位因亏损导致保证金不足以维持而被迫平仓,往往会损失大部分甚至全部初始保证金。了解如何设置爆仓预警并掌握避免强制平仓的技巧,对于管理合约交易风险至关重要。 设置爆…

    2025年12月8日
    000
  • 比特币止盈止损怎么挂最合理?能避开插针吗?

    在比特币等加密货币交易中,市场的剧烈波动是常态。这种波动性带来了潜在的收益,也伴随着显著的风险。有效的风险管理工具是交易者保护本金和锁定利润的关键,其中止盈和止损设置扮演着至关重要的角色。 止盈订单旨在当资产价格达到预设目标时自动卖出,锁定账面利润。止损订单则是在价格跌至某一水平时自动卖出,限制潜在…

    2025年12月8日
    000
  • RSI指标怎么看?RSI的计算方式和常见使用方法

    目录 1. RSI(相对强弱指数)的基本概念2. RSI的计算方式举例说明:步骤 1: 计算涨幅和跌幅步骤 2: 计算平均涨幅与平均跌幅步骤 3: 计算相对强度 (RS)步骤 4: 计算 RSI结果:RSI周期(参数)设置3. RSI 怎么看?常见使用方法介绍3.1. RSI 指标的超买与超卖判断3…

    2025年12月8日 好文分享
    000
  • KD随机指标是什么?KD随机指标的解读方法与计算公式

    目录 1. KD随机指标是什么?KD 指标的两种类型数值范围与过热区间2. KD随机指标的种类与计算公式快速随机指标(Fast Stochastic)慢速随机指标(Slow Stochastic)3. KD随机指标的解读方法与使用方式判断基准买入讯号:黄金交叉卖出讯号:死亡交叉背离(Divergen…

    2025年12月8日 好文分享
    000
  • Impossible Cloud Network(ICNT)是什么?怎么样?币安即将上线项目ICN全面介绍

    目录 一、ICN是什么?二、ICNT最新动态三、ICN与其他DePIN项目的对比及经济模型四、DePIN 赛道的下一阶段展望结语 5月底,icn(impossible cloud network)@icn_protocol 宣布获得 ngp capital 战略投资,估值达到 4.7 亿美元,很多人…

    2025年12月8日
    000
  • 2025年8月潜力加密货币盘点:巨鲸会购买哪个获得千倍收益?

    随着市场进入新的周期,投资者们正在积极寻找下一个可能带来巨大回报的领域。本文将深入探讨几个在2025年前景广阔的加密货币赛道,分析大型投资者(俗称“巨鲸”)可能会关注哪些项目,以期实现千倍级别的增长潜力。 2025年潜力加密货币赛道分析 要寻找千倍机会,我们不能只看已经众所周知的项目,而应关注那些正…

    2025年12月8日
    000
  • 币圈合约怎么开仓?永续合约是什么意思?合约交易新手教学

    币圈合约交易是一种使用少量资金控制较大价值资产的衍生品交易方式。它允许交易者对加密资产的价格走势进行投机,而无需实际拥有这些资产。进入合约市场需要了解其基本操作和相关概念。 如何在币圈合约市场开仓 1、选择一个提供合约交易服务的加密货币交易平台,并完成账户注册与实名认证。 2、向合约账户划转资金,这…

    2025年12月8日
    000
  • 虚拟数字币交易所APP最新版 v6.128.0 安卓正版

    虚拟数字币交易所app是一款功能强大的数字资产交易工具,致力于为全球用户提供安全、专业、便捷的交易服务。该平台支持多种主流及新兴的数字资产交易,拥有银行级别的安全防护体系和流畅的操作体验。本文为您提供了虚拟数字币交易所app最新v6.128.0安卓正版的官方下载渠道,用户只需点击文内提供的下载链接,…

    2025年12月8日
    000
  • 虚拟币app哪些正规 币圈十大正规虚拟币APP汇总

    随着数字资产在全球范围内的普及,对可靠且安全的数字资产交易平台的需量持续增。各类交易平台应而生,提供数字资产的买卖、存储以及其他相关服务。这些平台在促进数字资产流动性和价格发现方面发挥着至关重要的作用。选择一个合适的平台对于参与数字资产交易活动至关重要,这关系到资产的安全和交易的效率。下将列出一些在…

    2025年12月8日 好文分享
    000
  • 币圈合约跟单靠谱吗?跟单平台怎么选?

    币圈合约跟单作为一种投资方式,吸引了许多希望参与加密货币合约交易但不具备充足时间和专业知识的投资者。其基本原理是将自己的交易账户与平台上选定的优秀交易员账户关联起来,系统会自动同步该交易员的开平仓操作。用户无需手动分析行情和执行交易,由被跟随的交易员代劳。这种模式看似简化了交易过程,但也伴随着一系列…

    2025年12月8日
    000

发表回复

登录后才能评论
关注微信