gpt4 book ai didi

mysql - 0.1M流量如何提升数据库性能

转载 作者:行者123 更新时间:2023-11-29 04:40:27 30 4
gpt4 key购买 nike

我正在开发一个网站,我很关心性能。

在当前系统中存在向单个表添加 10,000 行的事务。插入大约需要 0.6 秒并不重要。

但我担心如果有 100,000 个并发用户并且其中 1000 个用户想要同时向单个表添加 10,000 行会发生什么情况。

与单个用户相比,这对性能有何影响?如果在这种情况下有大量流量,我该如何改善这些交易?

最佳答案

写入速度是强制要求时,我们解决它的方法是获得更快的硬盘驱动器。你提到事务,这意味着你需要你的数据持久(ACID 的 D)。此要求排除了 MyISAM 存储引擎或任何类型的 NoSQL,因此我将把答案集中在关系数据库上。

它的工作方式是这样的:您获得一组每秒输入输出操作数或每个硬盘驱动器的 IOPS。硬盘驱动器还有一个称为带宽的指标。您感兴趣的指标是写入速度。这里的一些粗略计算是这样的 - 每秒 MB 数除以 IOPS 数 = 每 IOPS 可以压缩多少数据。

对于机械驱动器,这个神奇的 IOPS 数字介于 150 和 300 之间——非常低。考虑到它们的带宽约为 100 MB/秒,您将获得真正少量的写入和每次写入的带宽。这就是固态硬盘发挥作用的地方 - 它们的 IOPS 数量从大约 5 000 开始(有些甚至达到 80 000),这对数据库来说非常棒。

在 RAID 中连接这些驱动器可为您提供超快速的存储解决方案。如果您能够将 10,000 次插入压缩到一个事务中,磁盘将尝试通过 1 IOPS 压缩所有 10k 插入。

另一种策略是对表进行分区并使用多个驱动器来存储 MySQL 的数据。

这是您安装单个 MySQL 所能达到的最大程度。有将数据分发到多个 MySQL 节点等的策略,但我认为这超出了您的问题范围。

TL;DR:您需要更快的磁盘。

关于mysql - 0.1M流量如何提升数据库性能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30259443/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com