温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

分析ecbil数据库插入速度慢的原因与解决方案

发布时间:2020-08-05 14:14:49 来源:网络 阅读:393 作者:necther 栏目:数据库
专题描述研发团队抛出问题如下:
折扣引擎在向数据库插入数据时,90万数据需要一个小时
分析过程1计算得出每秒插入行数只有250左右,远低于正常性能范围。
2和开发人员沟通发现,插入数据库的语句每次insert一行。
3配合开发团队人员,在压测时查看数据库,发现压测期间MySQL数据库完整占用一个数据库核心(top命令显示mysqld的cpu占用率在100%左右),瓶颈为单核cpu的运算能力。通过查看数据库连接情况进一步确认,一个数据库上,只有一个连接在插入数据。
解决方案1insert语句修改为批量插入数据。使用insert into ... values (),(),...,();小批量提交事务。优点缺点
修改简单可能需要修改max_allowed_packet参数。
2修改程序,使用合适的并发度,并发多线程插入数据。
(备注,方案1、2可以同时使用)
效果预计非常明显应用程序需要较大的改造。
问题原因1对MySQL数据库的操作方式不够优化。
知识点1MySQL对一条SQL语句,只能利用一个cpu核心处理,可能成为瓶颈。
2insert into ... values (),(),...,();一次插入多行数据,可以减少网络来回次数,以及数据库事务数量,从而提高性能。


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI