0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

丢包问题如何解决?方法在这里

亿佰特物联网应用专家 2022-10-14 10:23 次阅读

关于丢包的问题

无线通信最常见的问题就是丢包,无论是简单原始的433MHz通信,还是高精尖的5G信号,都会有丢包问题。解决丢包问题也是无线工程师的必要工作,丢包不可避免,但是遇到丢包了应该怎么办才是本文要谈的。无线通信最重要的就是设计一套能够解决应用需求的通信协议,而通信协议包含这些要素:无线信号使用什么频段、什么调制方式不被干扰、无线信号发给谁、如何保证无线信号送达目标、多个相同的设备同时使用该怎么办、接收端如何判断收到的信号是否重复收或漏收……其实这些都是围绕解决一个问题——丢包。

所以任何一种普遍使用的无线通信协议,都要分成若干逻辑层,每一个逻辑层。例如常见的Wi-FiZigBee蓝牙,它们都具备两个共同的逻辑层——PHY物理层,MAC链路层。其中PHY层定义了频段、调制方式以及传输方式。MAC层则定义了谁来发信号,谁来收信号,什么时候发信号。基本的PHY层和MAC层解决了常见的物理丢包问题,但是无线设备的应用场景十分复杂,因此各种通信协议之上还增加了诸如网络层这些逻辑层用于保证通信的稳定性,如Wi-Fi协议上 的TCP协议就是为了保证传输稳定而设计的。例如ZigBee的PHY层和MAC层就为了减少丢包做了一些处理机制。

减少丢包处理机制

①PHY层的减少丢包机制:
物理层的丢包,就是发送端发送了信号,但是接收端没有接收到信号。这也是最简单也是最常见的原因,通常就是发射端的功率低了,发射端距离接收端太远。遇到这种情况,通常会想到的办法就是提高发射功率,信号能发射得更远。但是根据香农定律,在相同信道带宽下,信号携带的信息量越少,对信噪比的需求越低,对信噪比需求越低就意味着对功率的需求越低。这时除了提高功率,还有一种方式就是扩频。比如典型的ZigBee上使用的DSSS扩频,原本ZigBee的信道带宽有2MHz,也就是能在1秒钟内输出2M个0或1的信号。通常我们使用8个0或1的信号表示一个字节,但是DSSS的作用下,需要64个0或1的信号来表示一个字节。这样使用无线信号传输一个字节需要64个0或1,即使信号在传输过程中发生了失真,接收端也能对信号进行纠错。这也就是为什么ZigBee的传输稳定性优于433MHz通信。正常情况下,ZigBee在20dBm发射功率的情况下,传输距离可达1公里。40390aa2-4b31-11ed-b116-dac502259ad0.png还有一种情况,就是天线的问题。任何一种天线都有天线增益系数以及方向性。通常外置天线的增益就优于PCB天线,在设备空间充足的情况下尽量选择外置天线。而天线的方向性也是要考虑的因素,例如棒状天线的信号覆盖范围就是一个扁球体,平行天线的位置信号非常好,而天线轴线延长线位置信号差得多。
②MAC层减少丢包的机制:以ZigBee的IEEE802.15.4系列协议为例,该协议的MAC层具有一下几个重要的功能。载波侦听和CSMA机制:IEEE802.15.4具备基于载波侦听的CSMA机制。设备在每次发射信号前,会侦听当前信道是否繁忙,并在信道空闲的时候发射信号。很多sub-G芯片也带有载波侦听功能的,但是缺少类似CSMA这样的协议机制。CSMA则规定了信道侦听的方法:发射前在一个随机时间内持续侦听信道,这样就能适当避免两个相同的设备同时发射信号;随机时间到达后尝试发送信号,如果发送失败就再侦听一次,并且下一次随机时间范围继续扩大(2倍),这样就能避免更多的设备同时发射信号;如果多次尝试都失败,而且达到了最大次数限制,那么这个信号就算丢包了。自动应答机制:IEEE802.15.4-MAC层有两种主要通信方式:广播和点播。点播到目标时,目标节点会返回ACK帧。发送端没有收到ACK帧,会尝试重传信号,如果多次重传都没收到ACK就算丢包。另外接收端回复MAC-ACK的时候是不受CSMA机制可以强行发送的,发送端在CSMA机制下成功将点播信号送出去后,只需要0.2~0.5毫秒就能收到ACK。

因此,导致MAC层丢包常见的现象就是CSMA失败丢包和MAC-ACK失败丢包,和物理层的丢包不同的是这两种丢包都可以被发送端自己检测到。通常遇到这种丢包,应用上的处理就是重传。但是重传也是要讲究科学性的,比如恶意信号干扰导致CSMA失败重传就没法解决;接收目标不存在导致的 MAC-ACK失败重传也是没法解决的。PHY层和MAC层的一系列处理机制都是为了减少丢包而设计的,但是无法保证绝对没有丢包,因此无线应用设计中,最关键的就是遇到丢包了该怎么办。

无线应用中丢包解决方法

以ZigBee传输为例,PHY层、MAC层、NWK层做了很多处理机制,丢包率几乎达到0.1%~0.01%。但是如果应用设计没考虑到仅剩的0.1%~0.01%丢包问题,对应用自身的影响就是致命的。在应用中常见的对丢包的容错,有如下解决办法。4050ae0a-4b31-11ed-b116-dac502259ad0.jpg①合理重传:重传是大家都能想到的方法,ZigBee就提供了CSMA失败检测和ACK失败检测。通常遇到以上两种情况大家的常见做法就是数据重传。但是重传也要讲究合理性,例如CSMA失败,这个时候有可能是很多个节点同时在发射信号;例如设备上电的时候会把上电时的信息上报给网关,多个设备一起上电肯定会有很大的冲突率,CSMA失败是很常见的事。因此,这时候遇到CSMA失败不要立即重传,可以随机延时100毫秒~1秒再重传,如果再次失败说明同时传输的设备确实太多,再随机延时2~4秒,失败再随机延时4~8秒……。如果是ACK失败则可以根据该次发射数据的实时性,延迟一个固定时间再重传,一般在1秒以上5秒以下,因为有可能上次传输失败是目标节点“不在状态”,下次传输可能就自动好了。②设计时序规则:应用数据传输时需要考虑出现丢包时该如何处理,例如OTA升级,文件传输。每一帧数据都是必不可少的,而且顺序还要正确。所以这类无线传输应用中,应该对每一帧数据包都标注上序号。发送端一旦检测到丢包,可能会重传数据帧。而接收端有可能是因为ACK没有发送到发送端导致发送端误判。如果接收端收到多一帧或少一帧数据,都可以从每一帧的序号判断出来。③该放弃时要放弃:类似接收端不存在,或者信道遇到干扰的问题,通过MAC层都可以侦测到。例如出现连续长时间的ACK失败,可能就是接收端不存在;连续长时间的CSMA失败,可能就是遇到了干扰。接收端不存在的情况下完全可以放弃对这个接收端发送消息。信道被干扰的情况下可以做整体信道切换,也可以暂停全网络的运行,保存当前状态,等待干扰消失后再恢复全部的传输。

不算丢包的“丢包”

无线通信上除了无线信号导致的丢包,还有软件逻辑上的丢包。典型的就是通信的数据量超过了发送端或接收端的处理能力。比如ZigBee的传输速率只有250kbps,加上CSMA延迟,路由转发,实际数据传输速率能够达到5kbps~10kbps就很不错了。发射端的应用程序如果向发射端写入数据的速度超过了发射端的传输速度,也会导致软件丢包。通常各家芯片厂商的IEEE802.15.4的协议栈都会提供一个Send Confirm的回调接口,应用程序向传输接口写入需要传输的消息后,约在几毫秒到几十毫秒内收到Send Confirm回调触发。同时一般射频芯片SoC也会提供缓存来存储写入的数据帧,有可能应用程序一次向射频芯片写入多个数据帧都被芯片SOC缓存起来,再慢慢的一帧一帧发射出去,然后Send Confirm回调被陆陆续续地触发。如果应用程序在发送消息的时候,每次向射频SoC写入传输消息,待Send Confirm触发后再写入下一条消息,就可以很好地规避软件丢包的问题。4081abae-4b31-11ed-b116-dac502259ad0.png

对于接收端也是如此,多个发送端向同一个接收端发送消息,CSMA很好的规避了冲突,发送端收到了各自的ACK,但是发送端发送的消息在接收端没有得到正确的响应。那么就有可能是接收端的处理能力有限,各个发送端累计发送的消息全部堆在接收端正在处理,这种情况就要考虑系统设计问题,减少接收端的处理压力。

总结

对于丢包的容错处理是无线通信设计的关键,现有成熟的通信协议虽然做了很多措施来降低丢包率,如果丢包一旦发生一定要有容错机制来应对,否则就算是千分之一或万分之一的丢包,都会为整个无线系统带来灾难性的后果。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 通信
    +关注

    关注

    18

    文章

    5706

    浏览量

    134400
收藏 人收藏

    评论

    相关推荐

    DDR硬件设计要点都在这里

    有的芯片还有VDDL,是给DLL供电的,也和VDD使用同一电源即可。电源设计时,需要考虑电压,电流是否满足要求,电源的上电顺序和电源的上电时间,单调性等。电源电压的要求一般在±5%以内。电流需要根据使用的不同芯片,及芯片个数等进行计算。
    发表于 12-18 15:56 426次阅读
    DDR硬件设计要点都<b class='flag-5'>在这里</b>

    关于电源纹波的那些硬核内容都在这里了!

    是随机信号,随着时间变化在直流输出电平上来回波动的交流量,周期和幅值不是固定的。 这里需要和电源噪声相区别,电源噪声一般是指全带宽下输出电压上叠加的交流量。电源纹波是低频噪声,测量需要将带宽限制在20MHz,而电源
    的头像 发表于 12-07 06:32 329次阅读
    关于电源纹波的那些硬核内容都<b class='flag-5'>在这里</b>了!

    48V电源系统可恢复eFuse的设计秘诀,在这里

    48V电源系统可恢复eFuse的设计秘诀,在这里
    的头像 发表于 12-05 10:09 376次阅读
    48V电源系统可恢复eFuse的设计秘诀,<b class='flag-5'>在这里</b>!

    有关eFuse电子保险丝,你应该了解的技术干货,都在这里

    有关eFuse电子保险丝,你应该了解的技术干货,都在这里
    的头像 发表于 12-04 10:20 915次阅读
    有关eFuse电子保险丝,你应该了解的技术干货,都<b class='flag-5'>在这里</b>!

    J-Link 中的JTAG 接口:正确使用需要了解的注意事项,在这里

    J-Link 中的JTAG 接口:正确使用需要了解的注意事项,在这里
    的头像 发表于 12-01 16:01 720次阅读
    J-Link 中的JTAG 接口:正确使用需要了解的注意事项,<b class='flag-5'>在这里</b>!

    这个MOS管在这里的作用是什么?是不是刚上电,MOS管是导通的,C115和R255是充电嘛?到上电稳压后MOS就不导通了嘛?

    这个MOS管在这里的作用是什么?是不是刚上电,MOS管是导通的,C115和R255是充电嘛?到上电稳压后MOS就不导通了嘛?
    发表于 11-11 11:32

    AT32F407/437使用网口收发数据问题处理

    AT32F407/437使用网口收发数据问题处理AT32F407/437 在使用EMAC 网口进行以太网数据收发时,如果出现数据,应该如何处理?
    发表于 10-23 08:19

    [HPM杂谈]你想要了解的先楫hpm_sdk开发都在这里系列 (二)

    一、概述在上一篇杂谈文章《[HPM杂谈]你想要了解的先楫hpm_sdk开发都在这里系列(一)》,大概分析了先楫通用单片机开发与其他国产单片机的开发差异,以及开发优劣势。刚好在这个月底,先楫官方发布
    的头像 发表于 10-12 08:18 972次阅读
    [HPM杂谈]你想要了解的先楫hpm_sdk开发都<b class='flag-5'>在这里</b>系列 (二)

    esp8266透传tcp如何防止

    esp8266透传tcp如何防止
    发表于 09-25 08:09

    使用agile_modbus主机协议栈出现是怎么回事?

    使用agile_modbus主机协议栈,接10个从机,测试发现从机接的越多,率越高。实际测试10个从机,每个从机间隔2s读一次,半个小时大概5帧报文。接7个从机,每个从机间隔2s读一次,半个小时100%的成功率,这是怎么回
    发表于 09-03 14:38

    NUC980 USB2.0 HighSpeed虚拟串口在Win10通信何解决?

    NUC980 USB2.0 HighSpeed 虚拟串口在Win10通信问题 最近使用USB虚拟串口与PC机Win10下做了一个高速单向通信实验(Win10 接收),发现有一定的错误概率
    发表于 09-01 06:12

    英特尔 x 联想集团:未来的PC在这里诞生

    内新建的“先进系统创新实验室”。 在这里,两家公司的工程师们齐聚一堂,集思广益,以解决全球范围内最棘手的硬件和软件难题,打造更轻薄、更时尚、性能更强的笔记本电脑,满足消费者和企业的日常需求。 今年7月,英特尔和联想的高管,在位于联想上
    的头像 发表于 08-11 19:15 297次阅读
    英特尔 x 联想集团:未来的PC<b class='flag-5'>在这里</b>诞生

    M484的HSUSB设备口,ISO端点DMA操作下,测试数据如何解决?

    。 通过在DMA使能的位置放断点,现象非常明显。 有人遇到这个问题不?要如何解决? ISO端口在不用DMA的时候,我们也遇到过问题,之前官方也没解决,被我们找到方法绕过去了。
    发表于 06-19 07:39

    NUC980 USB2.0 HighSpeed虚拟串口在Win10通信问题如何解决?

    NUC980 USB2.0 HighSpeed 虚拟串口在Win10通信问题
    发表于 06-13 06:28

    使用6300EVK板子搭建LWIP TCP服务端,在响应客户端回传数据时无规律性的原因?

    使用官方6300EVK板子 搭建 LWIP TCP服务端在响应客户端回传数据时无规律性电脑PING连接也会
    发表于 05-26 08:10