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

thinkPhP5.1 框架开发订阅消息过程中遇到 MySQL 跑路的问题

  •  
  •   zxcf · 5 天前 · 970 次点击

    thinkqueue+supervisor,任务跑的时候,脚本出现 General error: 2006 MySQL server has gone away,这个问题应该是从哪方面去入手处理好点,网上找不到好的解释,麻烦大佬看看,个人感觉是任务开始跑了,第一次进来消息,数据库链接,如果后续很长时间没有消息进来,就没有数据库操作,导致 MySQL 超时,后续就一直在尝试重新链接,但是链接不上

    第 1 条附言  ·  3 天前
    TP5.0.6 版本已经修复了这个问题,加入了断线重连机制,在数据库配置文件中开启 break_reconnect=true 就可以了
    18 回复  |  直到 2019-02-14 09:53:07 +08:00
        1
    GTim   5 天前
    任务不多,断了重链
        2
    pynix   5 天前
    跑路。。
        3
    zengzizhao   5 天前
    处理 2006,出现时重新连一次 mysql
        4
    moult   5 天前 via iPhone
    跟连接池一样,一分钟左右就去查询一次 select 1 保活即可。
        5
    oldmatch   5 天前
    为啥需要这样
        6
    Trim21   5 天前
    跑路的翻译很灵性...
        7
    zengzizhao   5 天前
    某个长连接很久没有新的请求发起,达到了 server 端的 timeout,被 server 强行关闭。

    此后再通过这个 connection 发起查询的时候,就会报错 server has gone away
        8
    oldmatch   5 天前
    @moult 为啥需要这样呢?
        9
    zxcf   5 天前
    @zengzizhao 这样子的话这个 connection 能调用关闭连接吗,然后我在重新连接一次
        10
    yc8332   5 天前
    1.mysql 服务器端有配置的,空闲多久会被断掉,这个可以设置一下
    2.可以把队列进程定期重启一下(也可以避免内存泄露)
    3.修复框架的 bug,mysql 断线重连肯定有 bug。。

    这几种方式都可以修复这个问题
        11
    runAll   5 天前 via iPhone
    ini_set('default_socket_timeout', -1);
    看看是不是因为链接超时了
        12
    runningman   4 天前
    早遇到了。改了 tp 的源码,
        13
    zxcf   4 天前
    @runningman 虽然改源码是不好的,但是请问你改的啥,真香
        14
    runningman   4 天前
    @zxcf 源码不知道给你是否合适。其实感动很简单啊。楼上的几位其实已经说了。
        15
    wispx   4 天前 via iPhone
    我也遇到过,连接断开导致的,开始 tp5 的断线重连就可以了
        16
    wo642436249   4 天前
    mysql 主动断开连接了,可以在操作前,判断下连接是否可用,如果不可用,则删除之前的断开的连接,重新建立连接就行,tp5 中有相关的配置了
        17
    echo404   3 天前
    TP5 中可以直接配置数据库断线重连,将 break_reconnect 参数设置为 true 就行
        18
    zxcf   3 天前
    @echo404 TP5 确实在 5.0.6 版本已经修复了这个,配置开启就 OK 了,我还以为得自己写重连机制了
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   2194 人在线   最高记录 4346   ·  
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 22ms · UTC 10:06 · PVG 18:06 · LAX 02:06 · JFK 05:06
    ♥ Do have faith in what you're doing.
    沪ICP备16043287号-1