0

0

Swoole基础UDP协议支持_Swoole UDP基础说明技巧【说明】

雪夜

雪夜

发布时间:2026-03-11 20:49:44

|

657人浏览过

|

来源于php中文网

原创

udp服务器必须用swoole_sock_udp创建,不能复用tcp写法;需显式指定协议类型、使用on('packet')处理收包、sendto()发送时必须带完整地址和端口,且不可用浏览器测试。

swoole基础udp协议支持_swoole udp基础说明技巧【说明】

UDP服务器必须用 SWOOLE_SOCK_UDP 创建,不能复用TCP写法

很多人照着TCP服务代码改UDP,结果启动报错或收不到包——根本原因是构造Swoole\Server时漏了协议类型参数。TCP默认就是SWOOLE_SOCK_TCP,但UDP必须显式传入SWOOLE_SOCK_UDP,否则底层根本不识别为UDP套接字。

  • new Swoole\Server('0.0.0.0', 9502) → 默认是TCP,监听后客户端发UDP包会直接被系统丢弃
  • new Swoole\Server('0.0.0.0', 9502, SWOOLE_PROCESS, SWOOLE_SOCK_UDP) → 正确,启用UDP监听
  • 注意SWOOLE_PROCESS模式推荐用于UDP,协程模式(SWOOLE_BASE)下on('packet')回调行为不一致,容易误判连接状态

on('packet') 是唯一入口,没有 on('connect')on('close')

UDP无连接,所以on('connect')on('close')这些TCP专属事件在UDP里根本不会触发。所有逻辑都得塞进on('packet')回调里处理,包括校验、应答、限流甚至“模拟会话”。

What-the-Diff
What-the-Diff

检查请求差异,自动生成更改描述

下载
  • $client_info['address']$client_info['port'] 是每次收包时动态提供的,不能缓存复用——客户端可能NAT换端口,下次包就不是同一个$port
  • 空数据或超长包要主动拦截:if (empty($data) || strlen($data) > 65507) { $serv->sendto(...'bad packet'); return; }
  • 别试图在on('packet')里做阻塞IO(比如file_get_contents),会卡死整个worker;需异步调用或投递到task进程

sendto() 必须带完整地址+端口,且不能用 send()

TCP用send($fd, $data)靠连接上下文发数据,UDP没$fd,所有发送必须靠sendto($ip, $port, $data),参数一个都不能少,顺序也不能错。

  • 写成 $serv->sendto($client_info['address'], $client_info['port'], 'ok') → 正确
  • 漏掉$port或传0 → 发送失败,sendto()返回false,但不会抛异常
  • $serv->send($fd, ...) → 直接报错:Warning: Swoole\Server::send(): fd[xxx] is not connected
  • 若需广播,得自己循环调用sendto(),Swoole不提供原生UDP广播封装

客户端测试别用浏览器,用 php -rnetcat

浏览器走HTTP/TCP,根本发不出UDP包。常见错误是写个TP6控制器调Swoole\Client然后用浏览器访问——这实际走的是HTTP请求,和UDP完全无关。

  • 快速验证命令:echo "ping" | nc -u 127.0.0.1 9502(Linux/macOS)
  • PHP CLI一行测:php -r "$c=new Swoole\Client(SWOOLE_SOCK_UDP); $c->connect('127.0.0.1',9502); $c->send('test'); echo $c->recv();"
  • 如果recv()超时,先检查服务端是否真在运行:ss -uln | grep :9502,确认端口被swoole进程监听
UDP没连接状态、没重传保障、没顺序保证——你写的每行代码都要默认它可能丢、可能乱序、可能重复。真正难的不是启动服务,而是怎么在不可靠传输上做出可靠业务逻辑。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
swoole为什么能常驻内存
swoole为什么能常驻内存

swoole常驻内存的特性:1. 事件驱动模型减少内存消耗;2. 协程并行执行任务占用更少内存;3. 协程池预分配协程消除创建开销;4. 静态变量保留状态减少内存分配;5. 共享内存跨协程共享数据降低内存开销。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

306

2024.04.10

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

846

2023.08.22

macOS怎么切换用户账户
macOS怎么切换用户账户

在 macOS 系统中,可通过多种方式切换用户账户。如点击苹果图标选择 “系统偏好设置”,打开 “用户与群组” 进行切换;或启用快速用户切换功能,通过菜单栏或控制中心的账户名称切换;还能使用快捷键 “Control+Command+Q” 锁定屏幕后切换。

358

2025.05.09

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

495

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

449

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

3502

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2903

2024.08.16

tcp和udp的区别
tcp和udp的区别

TCP和UDP的区别,在连接性、可靠性、速度和效率、数据报大小以及适用场景等方面。本专题为大家提供tcp和udp的区别的相关的文章、下载、课程内容,供大家免费下载体验。

126

2023.07.25

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
swoole进程树解析
swoole进程树解析

共4课时 | 0.2万人学习

Swoole系列-从0到1-新手进阶
Swoole系列-从0到1-新手进阶

共29课时 | 1.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号