首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
sendto系统调用阻塞问题
### 问题描述 之前问过这个问题, tcp server(process模式)向客户端发送数据时, sendto偶尔会阻塞很长时间, 当时让我升级swoole, 当时我升级后还是有这个问题 之前问题: https://wenda.swoole.com/detail/107576 ### Swoole版本,PHP版本,以及操作系统版本信息 php7.4.12 swoole 4.5.7 centos kernel 4.18.20 ### 相关代码 ```php 'daemonize' => 1, 'reactor_num' => 8, 'worker_num' => 8, 'max_connection' => 10000, 'dispatch_mode' => 1, 'log_file' => LOG_PATH . '/error.log', 'buffer_input_size' => 1024 * 1024 * 6, 'buffer_output_size' => 1024 * 1024 * 6, 'socket_buffer_size' => 1024 * 1024 * 10, 'open_length_check' => true, 'package_max_length' => 1024 * 512, 'package_length_offset' => 6, 'package_length_type' => 'V', 'package_body_offset' => 10, 'heartbeat_check_interval' => 60, 'heartbeat_idle_time' => 600, 'open_tcp_nodelay' => true, 'hook_flags' => SWOOLE_HOOK_ALL, ``` ### 你期待的结果是什么?实际看到的错误信息又是什么? strace1878:15:36:22.725654 sendto(22, "SZP\0\0\0\0\0&+\1\0\3\0\0\0\5\0\0"..., 76614, 0, NULL, 0) = 76614 <0.889164> 耗时达889ms, 而我设置的缓冲区应是够了的 ???
发布于3年前 · 1 次浏览 · 来自
提问
lg430
### 问题描述 之前问过这个问题, tcp server(process模式)向客户端发送数据时, sendto偶尔会阻塞很长时间, 当时让我升级swoole, 当时我升级后还是有这个问题 之前问题: https://wenda.swoole.com/detail/107576 ### Swoole版本,PHP版本,以及操作系统版本信息 php7.4.12 swoole 4.5.7 centos kernel 4.18.20 ### 相关代码 ```php 'daemonize' => 1, 'reactor_num' => 8, 'worker_num' => 8, 'max_connection' => 10000, 'dispatch_mode' => 1, 'log_file' => LOG_PATH . '/error.log', 'buffer_input_size' => 1024 * 1024 * 6, 'buffer_output_size' => 1024 * 1024 * 6, 'socket_buffer_size' => 1024 * 1024 * 10, 'open_length_check' => true, 'package_max_length' => 1024 * 512, 'package_length_offset' => 6, 'package_length_type' => 'V', 'package_body_offset' => 10, 'heartbeat_check_interval' => 60, 'heartbeat_idle_time' => 600, 'open_tcp_nodelay' => true, 'hook_flags' => SWOOLE_HOOK_ALL, ``` ### 你期待的结果是什么?实际看到的错误信息又是什么? strace1878:15:36:22.725654 sendto(22, "SZP\0\0\0\0\0&+\1\0\3\0\0\0\5\0\0"..., 76614, 0, NULL, 0) = 76614 <0.889164> 耗时达889ms, 而我设置的缓冲区应是够了的 ???
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2020-12-21
lg430
server是通过这个方法发送的, 只填了前两个参数 Swoole\Server->send(int $fd, string $data, int $serverSocket = -1): bool
赞
0
回复
微信公众号
热门内容
作者其它话题
- tcp client bug
- 错误信号
- 内存泄露问题
- 几个小错误反馈
- 协程client问题
暂无回复的问答
- 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一直是同一个。没用使用到多进程啊。