V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
magiclobster
V2EX  ›  数据库

咨询下数据库并发问题

  •  
  •   magiclobster · 2017-04-24 17:57:43 +08:00 · 1005 次点击
    这是一个创建于 2802 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    2 条回复    2017-04-27 13:02:10 +08:00
    silenceeeee
        1
    silenceeeee  
       2017-04-25 00:51:00 +08:00 via iPhone
    通过 mysql 日志定位到具体是哪里锁等待超时比较好。这样的信息太抽象了
    Hozzz
        2
    Hozzz  
       2017-04-27 13:02:10 +08:00
    最简单的:把锁等待的时间全部取消,一直等下去_(:з」∠)_
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1186 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 19ms · UTC 18:14 · PVG 02:14 · LAX 10:14 · JFK 13:14
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.