Home
Document
Q&A
Video
Donate
Source Code
Code-Galaxy 云原生平台
Business
Swoole Tracker
Swoole Compiler
Login
Register
全部
提问
分享
讨论
建议
公告
开发框架
发表新帖
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 ……
发布于4月前 · 24 次浏览 · 来自
提问
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
分享
收藏
提问
分享
讨论
建议
公告
开发框架
评论
2022-01-06
Rango
 客户端发出`Reqest`的`TCP`包之后,内核一直在重传。直到超过最大重传次数后,返回连接关闭。 可设置`/proc/sys/net/ipv4/tcp_retries2`限制`TCP`重传的最大次数。 另外需要检查`MySQL`服务器是否存在网络问题,在路由器、交换机等网络层丢包,或者机器的网卡丢包,如系统高负载导致网卡中断处理不及时、`TCP`缓存区已满内核协议栈丢包等问题。
赞
0
回复
微信公众号
热门内容
- Swoole 4.8.10 已发布
- 云原生时代 PHP/Golang 项目如何实现微服务
- 异步风格的写法,如何同时开启http和websocket?
- 使用全局变量,一个worker进程同时执行多个onRequest协程问题
- HTTP服务器出发热更新,看到工作进程的worker_id也变了,但重新请求response的结果不更新
- 清空redis key
- PDO配置长连接在并发请求时候会报一个bug工作进程自动重启
- Swoole 团队云原生新项目 Code-Galaxy 介绍
- swoole 进程繁忙时候\Swoole\Process::kill($pid, SIGTERM)终止运行后出现一大堆僵尸进程
- 给官方建议 [SWOOLE LINUX 独立版本,加上PHP-event的扩展]
暂无回复的问答
- 关于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]
- 请问那个一键协程化的代码是放外面还是set里面
- 多个模型如何进行事务异常回退?
- websocket开启wss报错
- 协程tcp服务器如何使用多进程?recv()方法接收信息,打印出来的pid一直是同一个。没用使用到多进程啊。