magiclobster
V2EX  ›  数据库

咨询下数据库并发问题

  •  
  •   magiclobster · Apr 24, 2017 · 1741 views
    This topic created in 3349 days ago, the information mentioned may be changed or developed.

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

    2 replies    2017-04-27 13:02:10 +08:00
    silenceeeee
        1
    silenceeeee  
       Apr 25, 2017 via iPhone
    通过 mysql 日志定位到具体是哪里锁等待超时比较好。这样的信息太抽象了
    Hozzz
        2
    Hozzz  
       Apr 27, 2017
    最简单的:把锁等待的时间全部取消,一直等下去_(:з」∠)_
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1285 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 6b34f497 · 37ms · UTC 17:15 · PVG 01:15 · LAX 10:15 · JFK 13:15
    ♥ Do have faith in what you're doing.