立即打开
来,看看MySQL插入速度能有50W每秒吗

来,看看MySQL插入速度能有50W每秒吗

写入速度

  • MySQL每秒可以插入50w条记录吗?
  • 带着疑问,我们一起看看mysql每秒可以插入多少条记录?
  • 要回答这个问题,首先要考虑影响mysql插入速度的因素有哪些?

硬盘的速度,网卡的速度,写入行的数据量,数据在硬盘中的存放位置等等因素。

简单的数据,插入速度肯定快,复杂的插入肯定慢。

所以单纯这个问题不好回答,最好的办法是进行压力测试,最后求一个平均值。

一 测试环境:

MySQL表结构

 

电脑配置

4核 Intel(R) Core(TM) i3-8100 CPU @ 3.60GHz

ssd 120G硬盘

二. 开始测试

说明:单机测试,不涉及网卡,网络传输的影响

测试程序php pdo

 

1.无任何索引,单进程

 

耗时50s, 平均2w/秒

2. 给name添加普通索引

 

大概慢了10s ,所以索引会导致插入变慢,因为要更新索引

来,看看MySQL插入速度能有50W每秒吗
负载

3. 多进程测试

用go写了一个简单的多进程执行程序

  
来,看看MySQL插入速度能有50W每秒吗
4进程负载

结果:

耗时115s ,插入速度平均3.4w/s

MySQL锁表状态

来,看看MySQL插入速度能有50W每秒吗
mysql status

10进程一起执行

来,看看MySQL插入速度能有50W每秒吗
10进程

耗时5‘10“ ,插入速度大概3.2w/s

MySQL锁表状态

来,看看MySQL插入速度能有50W每秒吗
MySQL status

最后:

  • 可见,插入速度并没有网上说的那么高,随着进程数增多,锁冲突逐渐增加,插入效率下降。
  • 通过存储过程批量进行插入 ,插入速度应该会更高,但在实际高并发应用中使用并不多!
  • 抛开业务,单纯测这个好像没什么意义,一定要结合业务复杂度,性能需求来做测试,做优化。
  • 通过分布式、拆表提高并发量。

不足之处,请各位指正。

【责任编辑:未丽燕 TEL:(010)68476606】

热门评论

还没有评论,快来说两句

打开时讯快报  查看更多

推荐阅读