当前位置:首页 > 文章列表 > 文章 > php教程 > php串口通信超时怎么处理_php设置超时时间避免阻塞【教程】

php串口通信超时怎么处理_php设置超时时间避免阻塞【教程】

2026-02-06 12:12:06 0浏览 收藏

有志者,事竟成!如果你在学习文章,那么本文《php串口通信超时怎么处理_php设置超时时间避免阻塞【教程】》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

PHP串口超时无效的根本原因是阻塞式read()陷入内核态,使PHP计时器失效;正确方案是用stream_select()配合非阻塞模式或使用php-ext-serialport扩展实现可控超时。

php串口通信超时怎么处理_php设置超时时间避免阻塞【教程】

PHP 本身不原生支持串口通信,所谓“PHP 串口超时”问题,本质是调用外部工具(如 stty + cat/echo)或扩展(如 php_serialphp-ext-serialport)时,底层系统调用未设置超时导致的永久阻塞。直接在 PHP 层用 set_time_limit()ini_set('max_execution_time') 无法中断正在等待串口数据的系统调用。

为什么 set_time_limit() 对串口读写无效

PHP 的执行时间限制只作用于 PHP 用户态代码,而串口读写(如 fread()stream_get_contents())在阻塞模式下会陷入内核态的 read() 系统调用。此时 PHP 解释器已暂停调度,计时器停止,超时机制完全失效。

  • fopen('/dev/ttyUSB0', 'r+') 后直接 fread($fp, 1024) —— 若设备无响应,PHP 进程将卡死
  • pcntl_alarm() 在大多数 Linux 发行版中无法中断 read(),尤其当串口被 stty 配置为 canonical 模式时
  • 即使使用 stream_set_timeout(),它仅对 socket 流生效,对串口文件流(php:// 以外的普通文件路径)完全不生效

正确做法:用 stream_select() 实现非阻塞轮询

必须将串口文件描述符设为非阻塞,并用 stream_select() 管理 I/O 就绪状态。这是唯一可移植、可控的 PHP 层超时方案。

  • 打开串口后,立即调用 stream_set_blocking($fp, false)
  • 每次读取前,用 stream_select() 检查流是否就绪,指定超时秒数和微秒数
  • stream_select() 返回 0,说明超时;返回 >0 才调用 fread()
  • 注意:串口需提前用 stty 配置为 raw 模式,否则可能因行缓冲行为导致 stream_select() 始终不就绪
#!/usr/bin/env php
<?php
$fp = fopen('/dev/ttyUSB0', 'r+');
if (!$fp) die("无法打开串口\n");

// 设置为非阻塞
stream_set_blocking($fp, false);

// 配置 stty(实际项目中建议提前执行一次)
exec('stty -F /dev/ttyUSB0 9600 cs8 -cstopb -parenb -icanon -echo -echoe -echok -echoctl -echoke -ixon -crtscts');

// 准备 select
$read = [$fp];
$write = null;
$except = null;

// 等待最多 2 秒
if (stream_select($read, $write, $except, 2, 0) > 0) {
    $data = fread($fp, 1024);
    echo "收到: " . bin2hex($data) . "\n";
} else {
    echo "串口读取超时\n";
}

fclose($fp);
?>

更可靠的方案:改用 php-ext-serialport 扩展

社区维护的 php-ext-serialport(GitHub 可搜)提供了真正的带超时参数的读写函数,底层封装了 select()ioctl() 控制,比纯 PHP 轮询更稳定。

  • 安装后可用 SerialPort::open(),传入 ['timeout' => 3000](毫秒)
  • $port->read(1024) 会在超时后抛出 SerialPortException,而非阻塞
  • 避免手动处理 stty、非阻塞标志、信号中断等底层细节
  • 注意:该扩展需编译安装,不支持 Windows;PHP 8.1+ 需确认兼容性

真正决定串口是否超时的,从来不是 PHP 的时间配置,而是你有没有让内核放弃「等数据来」的执念。用 stream_select() 或专用扩展,本质上是在告诉操作系统:“我只等 X 秒,过了就继续干活”。漏掉这步,所有 PHP 层的 timeout 设置都是幻觉。

理论要掌握,实操不能落!以上关于《php串口通信超时怎么处理_php设置超时时间避免阻塞【教程】》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

Golang如何实现Web静态资源管理_Golang Web静态资源管理实践详解Golang如何实现Web静态资源管理_Golang Web静态资源管理实践详解
上一篇
Golang如何实现Web静态资源管理_Golang Web静态资源管理实践详解
来看小说网热门小说排行榜-来看小说网全本小说免费在线阅读
下一篇
来看小说网热门小说排行榜-来看小说网全本小说免费在线阅读
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    3915次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    4242次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    4133次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    5352次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    4507次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码