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

2019-02-12 17:40:44 +08:00
 zxcf

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

6264 次点击
所在节点    PHP
19 条回复
GTim
2019-02-12 17:45:22 +08:00
任务不多,断了重链
pynix
2019-02-12 17:48:43 +08:00
跑路。。
zengzizhao
2019-02-12 17:53:55 +08:00
处理 2006,出现时重新连一次 mysql
moult
2019-02-12 17:54:54 +08:00
跟连接池一样,一分钟左右就去查询一次 select 1 保活即可。
oldmatch
2019-02-12 17:56:03 +08:00
为啥需要这样
Trim21
2019-02-12 17:56:05 +08:00
跑路的翻译很灵性...
zengzizhao
2019-02-12 17:56:07 +08:00
某个长连接很久没有新的请求发起,达到了 server 端的 timeout,被 server 强行关闭。

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

这几种方式都可以修复这个问题
runAll
2019-02-12 18:05:37 +08:00
ini_set('default_socket_timeout', -1);
看看是不是因为链接超时了
runningman
2019-02-12 18:16:58 +08:00
早遇到了。改了 tp 的源码,
zxcf
2019-02-12 18:31:34 +08:00
@runningman 虽然改源码是不好的,但是请问你改的啥,真香
runningman
2019-02-12 21:06:04 +08:00
@zxcf 源码不知道给你是否合适。其实感动很简单啊。楼上的几位其实已经说了。
wispx
2019-02-12 22:59:56 +08:00
我也遇到过,连接断开导致的,开始 tp5 的断线重连就可以了
wo642436249
2019-02-13 17:12:52 +08:00
mysql 主动断开连接了,可以在操作前,判断下连接是否可用,如果不可用,则删除之前的断开的连接,重新建立连接就行,tp5 中有相关的配置了
echo404
2019-02-13 22:27:15 +08:00
TP5 中可以直接配置数据库断线重连,将 break_reconnect 参数设置为 true 就行
zxcf
2019-02-14 09:53:07 +08:00
@echo404 TP5 确实在 5.0.6 版本已经修复了这个,配置开启就 OK 了,我还以为得自己写重连机制了
awanganddong
2020-12-04 09:53:02 +08:00
标记一下

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

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

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

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

© 2021 V2EX