mysql数据库每秒能写入多少条数据_数据库插入速度能有50W每秒吗

5c04aea34db742c42db2b5855b3b1868.png

写入速度

MySQL每秒可以插入50w条记录吗?

带着疑问,我们一起看看mysql每秒可以插入多少条记录?

要回答这个问题,首先要考虑影响mysql插入速度的因素有哪些?

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

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

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

一 测试环境:

MySQL表结构

CREATE TABLE `user_10w` (

`id` int(10) NOT NULL AUTO_INCREMENT,

`name` varchar(20) DEFAULT NULL,

`mobile` varchar(11) DEFAULT NULL,

`add_time` int(11) DEFAULT NULL,

`groupid` tinyint(1) DEFAULT NULL,

`login_time` int(11) DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=MyISAM AUTO_INCREMENT=4730016 DEFAULT CHARSET=utf8mb4

电脑配置

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

ssd 120G硬盘

二. 开始测试

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

测试程序php pdo

include_once("tool.php");

$dsn = 'mysql:dbname=demo;host=127.0.0.1';

$user = 'root';

$pass = 'root';

try{

$hand = new PDO($dsn, $user, $pass);

}catch(PDOException $e){

echo 'Connection failed: ' . $e->getMessage();

}

$query = $hand->prepare("insert into user_10w(name,mobile,add_time,groupid,last_login_time) values(?,?,?,?,?)");

$n=0;

$count = 1000000; //每次插入100w

$t = time();

echo 'start write,time is '. $t. "\\n";

while(true){

$n++;

$name = Tool::getRandomStr(5);

$mobile = Tool::getRandNum(9);

$group = Tool::getRandNum(1);

$rs = $query->execute([$name,'13'.$mobile,time(),$group,time()]);

if($n>$count)break;

}

echo 'write end, time is '. (time()-$t) . "\\n";

1.无任何索引,单进程

start write,time is 1593338798

write end, time is 50

耗时50s, 平均2w/秒

2. 给name添加普通索引

write end, time is 60

root@test:/data/php# php7 pdo.php

start write,time is 1593393695

write end, time is 61

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

0773e891a651a8d7df5106a9a4606ee4.png

负载

3. 多进程测试

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

package main

import(

"os/exec"

"sync"

)

var wg sync.WaitGroup

func testRun(wg *sync.WaitGroup){

c := exec.Command("php7", "./pdo.php")

c.Run()

wg.Done()

}

func main(){

var n int = 10

wg.Add(n)

for i:=0;i

go testRun(&wg)

}

wg.Wait();

}02eb58dce0e1dbc1dd6254e7ca168f40.png

4进程负载

结果:

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

MySQL锁表状态

de69a1629175ff68883b0f190049b26a.png

mysql status

10进程一起执行

5c2dd94b6a63a6c2f709c3e5e4b03951.png

10进程

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

MySQL锁表状态

7230be4f3148a0f7c66ef00edc7070b9.png

MySQL status

最后:

可见,插入速度并没有网上说的那么高,随着进程数增多,锁冲突逐渐增加,插入效率下降。

通过存储过程批量进行插入 ,插入速度应该会更高,但在实际高并发应用中使用并不多!

抛开业务,单纯测这个好像没什么意义,一定要结合业务复杂度,性能需求来做测试,做优化。

通过分布式、拆表提高并发量。

不足之处,请各位指正。

数据库是一个 单位或是一个应用领域的通用数据处理系统,它存储的是属于企业和事业部门、 团体和个人的有关数据的 集合。数据库中的数据是从全局观点出发建立的,按一定的 数据模型进行组织、描述和存储。其结构基于数据间的自然联系,从而可提供一切必要的存取 路径,且数据不再针对某一应用,而是面向全组织,具有整体的结构化特征。

### MySQL 数据库每秒最大读写次数 MySQL每秒最大读写次数取决于多种因素,包括硬件配置、网络环境以及具体的查询复杂度。对于高性能服务器,在理想件下,MySQL 可以支持非常高的吞吐量。 然而,具体数值会因不同版本和配置而异。一般来说: - 对于简单的 `SELECT` 查询,在优化良好的环境中,单台 MySQL 实例可能达到 **数万次** 每秒的查询速率[^1]。 - 写入操作通常比读取更消耗资源,因此其极限值可能会低于读取操作。通过采用合适的索引策略、批量插入等方式可显著提升写入效率[^2]。 为了进一步提高性能并突破单一实例的瓶颈,可以考虑实施主从复制机制来实现读写分离。这不仅有助于分散负载压力,还能增强系统的可用性和容灾能力。 当评估 MySQL 的实际性能时,建议使用基准测试工具如 Sysbench 或者 MySQL 自带的 benchmark 函数来进行精确测量。这些工具可以帮助确定特定工作负载下的最佳表现指标。 ```bash sysbench --db-driver=mysql \ --mysql-user=root \ --mysql-password=your_password \ oltp_read_write prepare sysbench --db-driver=mysql \ --mysql-user=root \ --mysql-password=your_password \ oltp_read_write run ``` 上述脚本展示了如何利用 sysbench 工具准备数据集并执行混合读写的压测实验。 #### 影响 MySQL 每秒读写次数的因素 - **硬件件**: CPU、内存、磁盘 I/O 和网卡速度都会影响最终的结果。 - **表结构设计**: 合理的设计能够减少锁争用,加快访问速度。 - **SQL 语句质量**: 高效简洁的 SQL 能够减轻数据库负担。 - **并发控制参数设置**: 如 InnoDB 缓冲池大小等关键参数调整也至关重要。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值