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

news/2024/7/5 2:05:59

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

最后:

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

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

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

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

不足之处,请各位指正。

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


http://lihuaxi.xjx100.cn/news/245788.html

相关文章

CSS3 从头捋

1.border-radius 边界半径 作用:该属性用来实现圆角 示例1实现圆角 div {border:2px solid red;width:300px;border-radius:25px; } 示例2实现圆 div {border: 1px solid red;height: 100px;width: 100px;border-radius: 50%; } 示例3 不规则圆 div {border: 1px s…

Win7封装无损廋身清单

整理了一下,大致如下。清理不会伤及系统功能。娱乐性的东西建议删除,因为这些不是功能性的,包括示例视频、示例音乐和一些主题图片以及一些系统自带的游戏。另外一些属于安装过程中产生的,重装封装不需要这些文件,对比…

mysql的调用有哪三种方式_MySQL数据库之mysql命令行中执行sql的几种方式总结

本文主要向大家介绍了MySQL数据库之mysql命令行中执行sql的几种方式总结 ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助。1.直接输入sql执行MySQL> select now();---------------------| now() |---------------------| 2013-09-18 1…

Postfix邮件服务搭建

最近发现邮件发送服务还是挺重要的。可能对于每天只有一百来封的邮件发送需求的个人博主来说,一个免费的邮箱提供的免费SMTP邮件发送服务就可以满足了,但是对于一些大型的网站、论坛和平台,每天的邮件发送量可以达到上万封以上,免…

快应用开发常见问题以及解决方案【持续更新】

接触快应用也有一段时间了,踩过了大大小小的坑,让我活到了今天。准备在此立贴持续更新,记录遇到的问题以及解决方案,造福大众。css 方面 1、文字竖排不支持 目前官方还不支持writing-mode,除了等待官方支持这个api以外…

CloudStack部署篇二 高级网络设置

CloudStack 4.2.1版本基础安装: http://51log.blog.51cto.com/6076767/1598046测试默认UI访问 http:ip1:8080/client/选择【我以前使用过cloudstack,跳过配置指南】;开始应用网络配置;一、 高级网络部署管理服务器 (mangermant m…

go 打印json 转义_Go 项目开发中 10 个最常见的错误

以下文章来源于Golang来啦 ,作者Seekload

objective-c系列-单例

// 地球只有一个,所以声明一个地球对象就可以了,千万不能声明两个啊!同理,有时候一个类也有只能有一个对象的情况,例如服务器,只想存到一个里 // 面,这样子,下次才可以取出上次存的数…