首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
mysql查询经常出现930多秒耗时问题
### 问题描述 1.上生产灰度少部分流量mysql查询经常出现930多秒耗时,旧系统没出现这种问题 2.使用的框架是:hyperf 2.2;使用的MySQL查询工具包是:[hyperf/database](https://github.com/hyperf/database) 3.系统8核,开了32个worker 4.耗时打点统计是在最终执行sql语句 ### Swoole版本,PHP版本,以及操作系统版本信息 swoole: 4.8.2 php: 7.4.24 os: CentOS Linux release 7.6.1810 (Core) ### 相关代码 对应swoole源码方法应该是: ``` inline bool check_liveness() { if (sw_unlikely(!check_connection())) { return false; } if (sw_unlikely(!socket->check_liveness())) { non_sql_error(MYSQLND_CR_SERVER_GONE_ERROR, MYSQLND_SERVER_GONE); close(); return false; } return true; } ``` 耗时统计打点最终定位位置:vendor/hyperf/database/src/Connection.php ```php runQueryCallback($query, $bindings, Closure $callback) ``` ### 你期待的结果是什么?实际看到的错误信息又是什么? 期待结果:解决MySQL查询出现932秒问题 错误信息:SQLSTATE[HY000]: General error: 2006 MySQL server has gone away (SQL: select * from ……
发布于2年前 · 27 次浏览 · 来自
提问
sifu
### 问题描述 1.上生产灰度少部分流量mysql查询经常出现930多秒耗时,旧系统没出现这种问题 2.使用的框架是:hyperf 2.2;使用的MySQL查询工具包是:[hyperf/database](https://github.com/hyperf/database) 3.系统8核,开了32个worker 4.耗时打点统计是在最终执行sql语句 ### Swoole版本,PHP版本,以及操作系统版本信息 swoole: 4.8.2 php: 7.4.24 os: CentOS Linux release 7.6.1810 (Core) ### 相关代码 对应swoole源码方法应该是: ``` inline bool check_liveness() { if (sw_unlikely(!check_connection())) { return false; } if (sw_unlikely(!socket->check_liveness())) { non_sql_error(MYSQLND_CR_SERVER_GONE_ERROR, MYSQLND_SERVER_GONE); close(); return false; } return true; } ``` 耗时统计打点最终定位位置:vendor/hyperf/database/src/Connection.php ```php runQueryCallback($query, $bindings, Closure $callback) ``` ### 你期待的结果是什么?实际看到的错误信息又是什么? 期待结果:解决MySQL查询出现932秒问题 错误信息:SQLSTATE[HY000]: General error: 2006 MySQL server has gone away (SQL: select * from ……
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2022-01-07
Rango
![](/storage/article-column/HbC91jyA5BpaRNhaVwUTmZYkXk5SpWDZSLbiX43d.png) 客户端发出`Reqest`的`TCP`包之后,内核一直在重传。直到超过最大重传次数后,返回连接关闭。 可设置`/proc/sys/net/ipv4/tcp_retries2`限制`TCP`重传的最大次数。 另外需要检查`MySQL`服务器是否存在网络问题,在路由器、交换机等网络层丢包,或者机器的网卡丢包,如系统高负载导致网卡中断处理不及时、`TCP`缓存区已满内核协议栈丢包等问题。
赞
0
回复
微信公众号
热门内容
暂无回复的问答
- CodeGalaxy K3s 轻量集群节点之间如何实现负载均衡
- 关于openssl CURL WARNING swSSL_connect: SSL_connect(fd=69) failed. Error: error:141A318A:SSL routines:tls_process_ske_dhe:dh key too small[1|394]
- 多个模型如何进行事务异常回退?
- websocket开启wss报错
- 协程tcp服务器如何使用多进程?recv()方法接收信息,打印出来的pid一直是同一个。没用使用到多进程啊。