问题是这样:我们系统有一个需求是会每隔 2 个小时会去数据库里把未完成的某类订单取出放到 mq (用的 redis )里进行消费,最近线上发现一个问题,在消费环节有时候会数据库报错: lock wait timeout ,然后项目就会报连接池满的错误 pool empty,导致连不上数据库 service 失败,现在没有定位到具体的问题:我的猜想一是并发导致?二是 service 里的事务时间太长导致,要优化 sql?三是或者是项目和数据库配置问题?项目是 spring 项目。不知道哪位高人能不能指导下,在数据量不大的时候好像没出什么问题。。目前的解决办法是出现 can't open connection 的时候重启了下项目释放,感觉不是长久之计。。
1
silenceeeee 2017-04-25 00:51:00 +08:00 via iPhone
通过 mysql 日志定位到具体是哪里锁等待超时比较好。这样的信息太抽象了
|
2
Hozzz 2017-04-27 13:02:10 +08:00
最简单的:把锁等待的时间全部取消,一直等下去_(:з」∠)_
|