百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

1分钟插入10亿行数据!抛弃Python,写脚本请使用Rust

off999 2024-10-21 06:51 30 浏览 0 评论

来源:Avinash

编辑:好困

【新智元导读】近日,一位程序员急需在一分钟之内生成十亿行的测试数据库,然而在用Python写了脚本之后发现「大失败」。怎么办?当然是用Rust了!


最近,一位程序员表示自己急需一个「也就」十亿行数据的测试数据库,并且还得在一分钟之内生成。


于是,他做了一个所有程序员都会做的事:写一个Python脚本来生成数据库。


然而,很不幸的是,这个脚本非 常 慢



于是,他又做了一个所有程序员都会做的事:进一步学习关于SQLite、Python以及不知道为什么还有Rust的知识。


项目已开源:https://github.com/avinassh/fast-sqlite3-inserts


目标

作者需要在他2019年的MacBook Pro(2.4GHz四核i5)上,一分钟内生成一个有10亿行的SQLite数据库


表的模式


要求:


  1. 生成的数据是随机的;
  2. 「area」列将包含六位数的地区代码(任何六位数都可以,不需要验证);
  3. 「age」列是5、10或15中的任何一个;
  4. 「active」列是0或1。


不过,作者表示,对脚本的要求也不用太高,还是可以妥协的:


  1. 如果进程崩溃,所有的数据都丢失也没有问题,再次运行脚本就可以了;
  2. 允许充分利用电脑的资源:100%的CPU,8GB的内存和剩余的SSD储存;
  3. 不需要使用真正的随机方法,来自stdlib的伪随机方法就可以。


Python原型

在最开始的脚本中,作者试图在一个for循环中逐一插入1000万条记录,而这让用时直接达到了15分钟



显然,这太慢了。


在SQLite中,每次插入都是一个事务,每个事务都保证它被写入磁盘,作者推断可能问题就来自这里。


于是作者开始尝试不同规模的批量插入,发现10万是一个最佳点,而运行时间减少到了10分钟



SQLite优化

作者认为自己写的代码已经很简练了,并没有什么可以优化的空间。


于是他将下一个目标转到了数据库的优化。


根据各种关于SQLite优化的建议,作者做了一些改进。



  • 关闭「journal_mode」将禁用回滚日志,也就是说,如果任何事务失败,都无法回滚。


  • 关闭「synchronous」,将使SQLite不再关心是否能可靠地写入磁盘,而是把这个责任交给操作系统。也就是说,可能会出现SQLite并没有成功写入磁盘的情况。


  • 「cache_size」指定了SQLite在内存中可以保留多少个内存页。


  • 当「locking_mode」为「EXCLUSIVE」模式时,SQLite锁住的连接将永远不会被释放。


  • 将「temp_store」设置为「MEMORY」可以让其表现像一个内存数据库。


此处作者提醒,请不要把这些操作用到生产上去。


重新审视Python

作者再次重写了Python脚本,这次包括了微调的SQLite参数,这次带来了巨大的提升,运行时间大幅减少:


  • 原始的for循环版本用时大约10分钟
  • 批处理版本用时大约8.5分钟


PyPy

PyPy在其主页上强调它比CPython快4倍,于是作者决定尝试一下。


令作者有些意外的是,竟然不需要对现有的代码进行任何改动,只需要在PyPy运行就可以了。


批处理版本只需要2.5分钟,也就是速度快了接近3.5倍


Busy Loop?

莫非是在Python的循环上耗费了太多时间?于是作者删除了SQL指令之后再次跑了一遍代码:


  • 批处理版本在CPython中用时5.5分钟


  • 批处理版本在PyPy中用时1.5分钟(又是3.5倍的速度提升)。


然而用Rust重写了相同的内容之后,循环只需要17秒


于是,作者果断抛弃Python转投Rust的怀抱。



Rust

像Python一样,作者先写了一个原始的Rust版本,一个循环执行一行数据的插入。


然而,即便使用了所有SQLite的优化,也依然消耗了大约3分钟。于是作者进行了进一步的测试:


  • 尝试把「rusqlite」换成异步运行的「sqlx」,这让用时直接被拉到了14分钟。作者表示,这比自己迄今为止写的任何一个Python迭代都要差。
  • 在执行原始SQL语句时,使用准备好的语句。这个版本的用时只有1分钟


最优的版本

使用准备好的语句,以50行为一个批次插入,最终用时34.3秒


作者又写了一个线程版本,其中一个线程从通道接收数据,还有四个线程向通道推送数据。


这个也是目前性能最好的版本,最终用时大约32.37秒




IO时间

SQLite论坛上的网友提出了一个有趣的想法:测量内存数据库所需的时间。


于是作者又跑了一遍代码,将数据库的位置设定为「:memory:」,rust版本完成的时间少了两秒(29秒)。


也就是说将1亿条记录写入到磁盘上需要2秒,这个用时似乎也是合理的。


这也说明,可能没有更多的SQLite优化可以以更快的方式写入磁盘,因为99%的时间都花在生成和添加数据上。


排行榜


插入1亿行数据的用时:
Rust33秒 PyPy126秒 CPython210秒


总结


  1. 尽可能使用SQLite PRAGMA语句


  1. 使用准备好的语句


  1. 进行分批插入


  1. PyPy确实比CPython快4倍


  1. 异步不一定更快


目前,第二快的版本是单线程运行的,而作者的电脑有4个核心,于是他在一分钟内可以得到8亿行数据。然后再经过几秒钟的数据合并,时间仍然可以少于一分钟。


网友评论


博主的这一番研究获得了网友们的一致好评。


真的很喜欢这些观点:

学习了更多关于PRAGMA语句。

PyPy的效率和灵活性可以通过即插即用的方式体现(将来一定会给它一个机会)。

文章的排版非常简单,有适当的源代码链接。很有趣,很容易上手。


Rust高光时刻又来了!



参考资料:

https://avi.im/blag/2021/fast-sqlite-inserts/

https://github.com/avinassh/fast-sqlite3-inserts

相关推荐

电脑虚拟机是什么(电脑虚拟机有啥用)

电脑虚拟机(VirtualMachine,VM),也称为虚拟计算机,是一种软件模拟的计算机,它在现有的计算机硬件上创建一个虚拟的计算机环境。这个虚拟环境可以用来运行操作系统、应用程序等软件,就像是在...

键盘图片大图(键盘图片大图清晰)

这个是仿苹果机上的无线键盘(妙控一代)的,属于山寨产品。1、在手机的微信或者短信或者其他可以打开键盘的应用中打开键盘,点击键盘左上角的输入法设置图标,页面显示输入法的各种设置功能;2、在输入法的设置...

win11系统可以更新吗(w11系统可以用了吗)

可以1.点击“开始”,打开“设置”。2.找到“更新和安全”,选择“预览体验计划”。3.点击“开始”,需要登录微软账户。4.登录完成后弹出一个升级的渠道,选择dev进行下载win11即可。方法二:首...

winxp安装系统镜像iso下载(xp的镜像系统怎么安装)

要安装一个ISO镜像文件,首先需要将ISO文件挂载到计算机上。在Windows系统中,可以右键点击ISO文件,并选择“挂载”选项,然后打开文件资源管理器就能看到ISO文件被挂载的虚拟驱动器。在Linu...

网易邮箱帐号注册(网易邮箱帐号注册网易游戏)
  • 网易邮箱帐号注册(网易邮箱帐号注册网易游戏)
  • 网易邮箱帐号注册(网易邮箱帐号注册网易游戏)
  • 网易邮箱帐号注册(网易邮箱帐号注册网易游戏)
  • 网易邮箱帐号注册(网易邮箱帐号注册网易游戏)
海尔电脑系统一键还原(海尔电脑怎么重置系统)
海尔电脑系统一键还原(海尔电脑怎么重置系统)

第一步:安装驱动程序保障计算机内至少有一个呵呵作系统且保证系统完好,如果有多个呵呵作系统,在呵呵作系统完好的情况下需要在各呵呵作系统内安装驱动程序,如果呵呵作系统为Windows98/ME,则需要安装haier98.exe;如果呵呵作系统为...

2025-12-27 01:51 off999

拼多多下载安装(拼多多下载安装免费2025版本)

一般有人问你有没有拼多多,都是想请你帮忙拼多多平台活动助力。          ...

联想电脑安装系统步骤(联想电脑安装系统教程)

联想电脑系统重装的方法如下1、制作好U盘启动盘,然后把下载的联想win7系统iso文件直接复制到U盘的GHO目录下:2、在联想电脑上插入U盘,重启后不停按F12或Fn+F12快捷键打开启动菜单,选择U...

ppt自动生成网站(ppt 自动生成)

可以使用以下方法一键生成PPT:1.使用PPT模板:选用一个PPT模板,将图片插入到模板中相应的位置即可。2.使用图像转换器:将多张图片转换成PPT格式,然后将它们放在PPT中的相应位置。3.使用第...

最好用的搜索引擎磁力吧(2020年推荐一波好用的磁力搜索引擎)

搜索引擎是指根据一定的策略、运用特定的计算机程序从互联网上搜集信息,在对信息进行组织和处理后,为用户提供检索服务,将用户检索相关的信息展示给用户的系统。搜索引擎的分类有:全文搜索引擎、目录索引类...

电脑装不了系统是什么原因(为什么我电脑装不了系统)

电脑不能安装新系统的原因可能有多种。可能是由于硬件不兼容,例如新系统需要更高的处理器或内存要求,而电脑的配置不足。另外,可能是由于硬盘空间不足或损坏,导致无法安装新系统。还有可能是由于操作系统安装文件...

win7忘记开机密码u盘启动(windows7忘记开机密码用u盘)

win7电脑忘记开机密码,之后可以通过PE的方式来进行启动。首先需要找一块U盘,然后再网上下载一个PE系统。把这块U盘做成PE系统启动盘,然后把电脑设置成U盘启动,这样就直接可以进入到系统,进去之后就...

开不了机的手机怎么处理(开不了机的手机怎么处理掉)

方法/步骤手机突然开不了机,先长按开机键,因为有的时候,现在的知道手机,突然关机了,系统一下子在死机状态,等你长了后,手机就会有一下振动的声音,你再放开手,再重新按开机键,就能开机了。如果长按还是开不...

cdlinux手机版(cdlinux最新版0.9.8)

Kali更好。1.首先,Kali是专门为渗透测试和网络安全而设计的操作系统,它拥有广泛的渗透测试工具和资源,使得用户在这个领域有更多的选择和更强大的功能。2.其次,Kali具有更长的发展历史和更大...

电脑cpu处理器排名天梯图(电脑cpu处理器天梯榜)

1.荣耀王者段位:A15处理器(5核GPU版)、A15处理器(4核GPU版)不论是从跑分上还是具体体验上,苹果最新的A15处理器都是佼佼者,CPU和GPU大幅领先于安卓现役旗舰SOC2.王者段位:骁龙...

取消回复欢迎 发表评论: