TSN协议原理!看完这一篇就够了(1)——时钟同步IEEE802.1AS-2020

2024-03-25 20:28

本文主要是介绍TSN协议原理!看完这一篇就够了(1)——时钟同步IEEE802.1AS-2020,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

▎前言

在许多应用场景中,一个本地局域网中互联的设备集群需要共享同一个时间,以支持各设备的协同工作。例如:音频设备与视频设备的配合播放,雷达与摄像头的数据融合等;这样一个看似简单的域功能,细化成为各节点的需求就变得不那么简单了。想象一下,A和B节点的绝对时间不同——A此刻时间为09:00:00,B的时间为09:00:05;时间频率不同——标准时间经过了1分钟,A节点计时59秒,B节点计时61秒;如何实现各节点的时间矫正,我们今天要讲解的802.1AS协议就是用来实现以上提到的功能的。

▎协议目的-共享时间

TSN任务组(Time-Sensitive Networking Task Group)是IEEE 802.1 Working Group的一个组成部分,它的目的是在IEEE 802网络上提供确定性连接。我们可以把确定性连接这个概念简单理解为网络包传输的低延时,低抖动和无丢包;TSN在汽车控制,工业自动化,电力自动化等领域的应用通过协议簇实现,例如时间同步机制类协议802.1AS,冗余机制类协议802.1CB,服务质量类协议802.1Qbv,Qav,Qbu等和安全机制类协议802.1Qci。在IEEE 802.1DG草案中定义了汽车车内以太网的通信配置要求,时钟同步机制采用802.1AS。

提供确定性连接的关键是共享网络中各组件的时间。802.1AS协议用于满足音频,视频等时间敏感应用和时间敏感控制场景下的时间同步需求;网络配置的更新,网络组件的增加,去除或者故障都不应影响同步功能。为此,协议规定了时间同步模型的架构,同步方法,节点的介质无关子层,介质相关子层具体实现方法。花费大量篇幅解释专业名词并非文章的核心,我们专注于基本概念、同步原理和实现形式。

▎基本概念-gPTP域

在讲解802.1AS协议之前,需要简单介绍一下IEEE 1588协议。IEEE 1588定义了一种精确时间协议,被称为precision time protocol,PTP。802.1AS基于PTP提出了自己的同步模型,并称之为generalized precision time protocol,gPTP。

下图给出了一个时间感知网络拓扑图。在这个网络系统中,由于所有的设备都具有gPTP能力,因此这个网络是一个gPTP域。虽然系统中存在网桥,路由器,终端站等多种设备,对于gPTP域来说只有两类,PTP终端节点(PTP End Instance)和PTP中继节点(PTP Relay Instance)。

如果节点只与一个节点连接,那么这是一个终端节点,比如图中的end station;如果节点与多个节点连接,那么这是一个中继节点,比如下图中的bridge和router;时间同步的最终效果是,所有的节点都以图中与stratum 1时钟源相连的bridge作为时间基准,并不断修正自己的时间;这个时间基准被称为主时钟(Grandmaster Clock,GM)。

图片来源:IEEE 802.1AS 2020
当网络出现故障时,例如外网与本地网络连接中断,本地网络中的所有设备会重新选择一个主时钟设备,也就是下图中的end station(local GM),作为自己的参考对象。

图片来源:IEEE 802.1AS 2020

▎同步原理-延时和频率比值

gPTP域中的时间修正通过发送和接收特定报文实现。首先确定主时钟节点和时间同步生成树,然后该节点会沿生成树方向发送时间同步报文,中继节点转将报文转发至下游节点,最终实现将GM时钟信息传递给域内所有节点。在时间同步过程中,存在两类延时:

  • 转发延时:报文在中继节点中停留的时间。转发延时是中继节点的本地属性,易于计算;
  • 传播延时:报文在链路上传播的时间。传播延时取决于很多因素,例如介质相关属性和链路长度。当两类延时时间都已知,各个节点通过累计报文到达前的转发延时和传播延时便可得到同步时间。

因此我们需要考虑:①如何选择GM时钟?②如何测量报文在同步路径中的延时?
在这里插入图片描述

GM时钟选择

有两种方法可以选择一个gPTP域内的主时钟:

  • 最优主时钟算法(Best Master Clock Algorithm, BMCA)

    使用BMCA来确定gPTP域的GM节点,并以该节点为根构建时间同步生成树。各节点之间通过发送Announce报文来交换最佳主时钟选择信息,通过两两对比报文内容,系统最终收敛到唯一的主时钟。

  • 预定义端口状态

    强制配置一个节点作为GM,并构建以该节点为根的时间同步生成树。

在车载网络中,主时钟是预先分配的,例如将TBOX作为GM,使用GPS时间作为同步时间。

延时测量

gPTP定义了两类报文用于时间同步,事件型报文和一般型报文。在PTP节点入口和出口打上时间戳的报文是事件型报文,没有打时间戳需求的是一般型报文。

  • 事件型报文:Sync、Pdelay_Req、Pdelay_Resp
  • 一般型报文:Follow_Up、Pdelay_Resp_Follow_Up

图片来源:IEEE 802.1AS 2020
传播延时测量方法为两步对等路径延时/对等延时,测量的方向为initiator向responder发起,通过Pdelay_Req、Pdelay_Resp和Pdelay_Resp_Follow_Up获取四个时间t1,t2,t3和t4,测量步骤和计算方法如下:

  • 请求方发送Pdelay_Req报文,记录出口时间戳t1
  • 应答方收到该报文,记录入口时间戳t2;此时请求方获取的时间是t1
  • 应答方反馈Pdelay_Resp报文,记录出口时间戳t3,并在报文中携带t2
  • 请求方收到该报文,记录入口时间戳t4;此时请求方获取的时间是t1,t2,t4
  • 应答方再次发送Pdelay_Resp_Follow_Up报文,并在报文中携带t3;此时请求方获取到时间t1,t2,t3和t4
  • 根据两个方向的时间差值计算传播延时

在这里插入图片描述
需要注意的是,这种测量方式不考虑链路方向的延时差异,假定请求方和应答方之间两个方向的报文传播时间是对称的;这种计算方法对应请求方和应答方走时一致的理想情况,而实际二者的频率差是必然存在的。当请求方的时钟频率比应答方的慢,D会比实际值小。感兴趣的读者可以自己计算一下。

转发延时的测量基于本地时钟,计算报文的出口时间戳和入口时间戳差值。

802.1AS并未规定传播延时测量的方向,但是在车载网络中,一般由Slave端向Master端发起。

由于时间频率不同会导致校准误差,我们需要得到相邻节点的时间频率rateRatio,并将其计入传播延时中。

计算方法为统计连续的Pdelay_Resp和Pdelay_Resp_Follow_Up报文时间戳信息。如下图所示,第一次发送Pdelay_Resp的时间为t3,到达另一端的时间为t4,第二次发送Pdelay_Resp的时间为t3’,到达时间为t4’。

在这里插入图片描述
频率比值计算结果为:

在这里插入图片描述
计入频率比值的传播延时为:

在这里插入图片描述
相邻节点之间的频率比被称为neighborRateRatio,节点与主时钟之间频率比被称为rateRatio;rateRatio是neighborRateRatio的累积乘积,而由于neighborRateRatio与1非常接近(以ppm为单位),实际计算中也可通过累计相加的方式得到。

在这里插入图片描述
传播延时一般是ns-μs量级,转发延时由于交换机转发与处理能力的限制,一般是μs-ms量级。因此,时间同步的误差来源主要是转发延时。

▎实现方式-PTP报文

延时测量方法,测量结果,PTP端口信息和发送周期在时间同步报文(PTP报文)中携带。PTP报文位于MAC帧的数据段,目的MAC地址为固定组播地址01-80-C2-00-00-0E,以太网帧类型为固定0x88F7。

在这里插入图片描述
PTP报头为34字节,包含报文类型messageType,PTP版本号versionPTP,PTP报文字节数messageLength等内容。

Correction field字段是上游节点相对于GM节点的修正值,换算成ns时间需要除以2^16。当follow_up报文中的originTimestamp加上该字段以后,就是上游节点发送该Sync报文的同步时间。

在这里插入图片描述

Sync报文

Sync报文根据一步法和两步法的不同,报文格式存在差异。一步法仅由Sync报文携带延时和频率比值信息。

图片来源:IEEE 802.1AS 2020
如果报头中的两步法标志位为True,那么Sync报文格式如IEEE 802.1AS 2020中的表11-8所示;如果标志位为False,那么Sync报文格式如IEEE 802.1AS 2020中的表11-9所示。由于一步法不发送Follow_Up报文,因此GM节点发送Sync报文的时间originTimestamp和TLV字段统一在Sync报文中携带。车载应用中,通常使用两步法。

在这里插入图片描述

Follow Up报文

Follow_Up报文携带相关Sync报文的出口时间戳信息。

preciseOriginTimestamp是GM节点发送Sync报文的时间。

在这里插入图片描述

Pdelay_Req报文

报文的数据段不携带信息,为保留值。
在这里插入图片描述

Pdelay_Resp报文

requestReceiptTimestamp为Responder接收Pdelay_Req报文的入口时间。

requestingPortIdentity为Pdelay_Req报文的源端口信息。

在这里插入图片描述

Pdelay_Resp_Follow_Up报文

responseOriginTimestamp为Responder发送Pdelay_Resp报文的出口时间。

requestingPortIdentity同样为Pdelay_Req报文的源端口信息。

在这里插入图片描述

▎总结

TSN任务组颁布了IEEE 802.1AS-2020协议以解决本地局域网中各组件的时间同步问题。在一个gPTP域中,各节点测量传播延时,转发延时和频率比值。通过BMCA算法或预配置方式,系统确定主时钟节点并向其他节点发送时间同步报文,完成时间同步。本期协议解读到此就告一段落了,下期我们将为大家带来更多精彩的TSN协议系列解读,敬请期待。

▎参考文献

[1] IEEE Std 802.1AS™‐2020 IEEE Standard for Local and Metropolitan Area Networks —Timing and Synchronization for Time‐Sensitive Applications

[2] IEEE Std 1588™-2008 IEEE Standard for a Precision Clock Synchronization Protocol for Networked Measurement and Control Systems

这篇关于TSN协议原理!看完这一篇就够了(1)——时钟同步IEEE802.1AS-2020的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/846157

相关文章

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

MySQL中的表连接原理分析

《MySQL中的表连接原理分析》:本文主要介绍MySQL中的表连接原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、表连接原理【1】驱动表和被驱动表【2】内连接【3】外连接【4编程】嵌套循环连接【5】join buffer4、总结1、背景

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实

Java Stream的distinct去重原理分析

《JavaStream的distinct去重原理分析》Javastream中的distinct方法用于去除流中的重复元素,它返回一个包含过滤后唯一元素的新流,该方法会根据元素的hashcode和eq... 目录一、distinct 的基础用法与核心特性二、distinct 的底层实现原理1. 顺序流中的去重

使用Python进行GRPC和Dubbo协议的高级测试

《使用Python进行GRPC和Dubbo协议的高级测试》GRPC(GoogleRemoteProcedureCall)是一种高性能、开源的远程过程调用(RPC)框架,Dubbo是一种高性能的分布式服... 目录01 GRPC测试安装gRPC编写.proto文件实现服务02 Dubbo测试1. 安装Dubb

Spring @Scheduled注解及工作原理

《Spring@Scheduled注解及工作原理》Spring的@Scheduled注解用于标记定时任务,无需额外库,需配置@EnableScheduling,设置fixedRate、fixedDe... 目录1.@Scheduled注解定义2.配置 @Scheduled2.1 开启定时任务支持2.2 创建

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源