咨询下数据库并发问题

2017-04-24 17:57:43 +08:00
 magiclobster

问题是这样:我们系统有一个需求是会每隔 2 个小时会去数据库里把未完成的某类订单取出放到 mq (用的 redis )里进行消费,最近线上发现一个问题,在消费环节有时候会数据库报错: lock wait timeout ,然后项目就会报连接池满的错误 pool empty,导致连不上数据库 service 失败,现在没有定位到具体的问题:我的猜想一是并发导致?二是 service 里的事务时间太长导致,要优化 sql?三是或者是项目和数据库配置问题?项目是 spring 项目。不知道哪位高人能不能指导下,在数据量不大的时候好像没出什么问题。。目前的解决办法是出现 can't open connection 的时候重启了下项目释放,感觉不是长久之计。。

987 次点击
所在节点    数据库
2 条回复
silenceeeee
2017-04-25 00:51:00 +08:00
通过 mysql 日志定位到具体是哪里锁等待超时比较好。这样的信息太抽象了
Hozzz
2017-04-27 13:02:10 +08:00
最简单的:把锁等待的时间全部取消,一直等下去_(:з」∠)_

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/357045

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX