MySQL使用pv命令来限制SQL执行速度
问题
我有个大的 SQL 文件要回放,需要马上做,但又怕压死业务,怎么办?
实验
先来建一个测试库:
塞一些数据进去:
看看我们塞数据的成果:
使用 mysqldump 导出一份数据:
现在我们假设要把这个 dump 文件,回放到一个数据库中,并且现在数据库正在承担很重的业务,我们不希望业务受到太大影响。
先来看看如果直接回放 dump 文件,会发生什么?
我们看到 MySQL 的 cpu 会彪起来,
我们换一个方式来回放 dump:
看看 CPU 压力:
可以看到 CPU 已经非常冷静,并且缓慢的处理数据。
💡小贴士:
pv 工具既可以用于显示文件流的进度,也可以用于文件流的限速。