PTP协议精讲(3.12):单播协商实现——PTP的“专线服务“
3.12 单播协商实现PTP的专线服务为什么需要单播默认PTP使用组播但有些场景需要单播组播的局限性 1. 跨网段问题 - 组播可能被路由器阻止 - TTL限制传播范围 - 需要组播路由支持 2. 网络负载 - 所有设备都收到所有报文 - 浪费带宽 - 不必要的处理 3. 精确控制 - 无法指定特定主时钟 - 无法控制服务质量 - 无法按需分配资源 单播的优势 1. 跨网段 - 穿越路由器 - 无组播限制 - 更广的覆盖范围 2. 按需服务 - 只发送给请求者 - 节省网络带宽 - 精确控制目标 3. 服务质量 - 可协商发送速率 - 可协商持续时间 - 灵活的参数配置 适用场景 - 跨路由器的PTP - 电信运营商网络 - 数据中心互联单播协商协议信令消息单播协商使用Signaling消息 Signaling Message结构 ┌─────────┬─────────┬──────────┬──────────┐ │Header │Target │TLV │TLV │ │34 bytes │Port ID │(Request) │(Grant) │ │ │10 bytes │Variable │Variable │ └─────────┴─────────┴──────────┴──────────┘ 包含的TLV - REQUEST_UNICAST_TRANSMISSION - GRANT_UNICAST_TRANSMISSION - CANCEL_UNICAST_TRANSMISSION - ACKNOWLEDGE_CANCEL_UNICAST_TRANSMISSION协商流程单播协商三步握手 步骤1请求从时钟→ 主时钟 Signaling消息包含 - REQUEST_UNICAST_TRANSMISSION TLV - messageType请求的消息类型Sync/Announce/Delay_Resp - logInterMessagePeriod发送间隔 - durationField请求的持续时间秒 步骤2授权主时钟 → 从时钟 Signaling消息包含 - GRANT_UNICAST_TRANSMISSION TLV - messageType同意的消息类型 - logInterMessagePeriod实际发送间隔 - durationField授权的持续时间 - flags授权标志 步骤3开始传输 主时钟按协商参数发送单播消息 从时钟接收并处理 步骤4取消可选 任何一方可以发送CANCEL_UNICAST_TRANSMISSION 对方响应ACKNOWLEDGE_CANCEL_UNICAST_TRANSMISSIONTLV结构详解REQUEST_UNICAST_TRANSMISSION/* tlv.h, 第283-289行 */structrequest_unicast_xmit_tlv{Enumeration16type;/* 0x0004 */UInteger16length;uint8_tmessage_type;/* 请求的消息类型 */Integer8 logInterMessagePeriod;/* 发送间隔log2秒 */UInteger32 durationField;/* 持续时间秒 */};消息类型编码message_type字段 bit 7-4消息类型 bit 3-0保留 编码 0x10 ANNOUNCE 0x20 SYNC 0x40 DELAY_RESP 0x50 PDELAY_RESP 示例 请求Sync消息message_type 0x20 请求Announce消息message_type 0x10 logInterMessagePeriod 发送间隔 2^logInterMessagePeriod 秒 示例 0每1秒发送一次 -3每0.125秒发送一次125ms 3每8秒发送一次GRANT_UNICAST_TRANSMISSION/* tlv.h, 第169-177行 */structgrant_unicast_xmit_tlv{Enumeration16 type;/* 0x0005 */UInteger16 length;uint8_tmessage_type;/* 消息类型 */Integer8 logInterMessagePeriod;/* 发送间隔 */UInteger32 durationField;/* 授权时长 */uint8_treserved;uint8_tflags;/* 授权标志 */};flags字段/* tlv.h, 第150行 */#defineGRANT_UNICAST_RENEWAL_INVITED(10)flags含义 bit 0RENEWAL_INVITED - 1主时钟邀请从时钟续约 - 0不邀请续约 续约流程 1. 授权即将到期 2. 主时钟设置RENEWAL_INVITED 1 3. 从时钟收到后可以提前请求续约 4. 避免服务中断 其他bits保留。CANCEL_UNICAST_TRANSMISSION/* tlv.h, 第162-167行 */structcancel_unicast_xmit_tlv{Enumeration16 type;/* 0x0006 */UInteger16 length;uint8_tmessage_type_flags;/* 消息类型和标志 */uint8_treserved;};取消流程取消场景 1. 从时钟不再需要服务 - 断开连接 - 切换到其他主时钟 - 停止同步 2. 主时钟无法继续服务 - 资源不足 - 设备关闭 - 配置变更 取消消息 CANCEL_UNICAST_TRANSMISSION TLV - message_type_flags要取消的消息类型 确认消息 ACKNOWLEDGE_CANCEL_UNICAST_TRANSMISSION TLV - 确认收到取消请求 - 停止发送/接收LinuxPTP实现unicast_client结构/* port.h中定义 */structunicast_client{LIST_ENTRY(unicast_client)list;structPortIdentityportIdentity;/* 目标端口ID */structPortAddressaddress;/* 目标地址 */uint8_tmessage_type;/* 消息类型 */Integer8 logInterMessagePeriod;/* 发送间隔 */UInteger32 durationField;/* 剩余时长 */structtimespecgrant_time;/* 授权时间 */intstate;/* 状态 */};发送请求/* port.c中的单播请求简化 */staticintport_request_unicast(structport*p,structunicast_client*client){structptp_message*msg;structrequest_unicast_xmit_tlv*req;/* 构造Signaling消息 */msgmsg_allocate();msg-header.messageTypeSIGNALING;/* 设置目标 */msg-signaling.targetPortIdentityclient-portIdentity;/* 构造REQUEST TLV */req(structrequest_unicast_xmit_tlv*)msg-management.suffix;req-typeTLV_REQUEST_UNICAST_TRANSMISSION;req-lengthsizeof(*req)-sizeof(structTLV);req-message_typeclient-message_type;req-logInterMessagePeriodclient-logInterMessagePeriod;req-durationFieldclient-durationField;/* 字节序转换 */tlv_pre_send((structTLV*)req,NULL);/* 发送 */returnport_tx(p,msg,p-trp);}处理授权/* port.c中的授权处理简化 */staticvoidport_handle_grant(structport*p,structgrant_unicast_xmit_tlv*grant){structunicast_client*client;/* 字节序转换 */grant-durationFieldntohl(grant-durationField);/* 查找对应的请求 */clientfind_unicast_client(p,grant-message_type);if(!client)return;/* 更新参数 */client-logInterMessagePeriodgrant-logInterMessagePeriod;client-durationFieldgrant-durationField;client-stateUNICAST_GRANTED;/* 记录授权时间 */clock_gettime(CLOCK_MONOTONIC,client-grant_time);pr_info(unicast grant received: type %u, interval %d, duration %u,grant-message_type4,client-logInterMessagePeriod,client-durationField);}发送单播消息/* port.c中的单播发送简化 */staticintport_tx_unicast(structport*p,structptp_message*msg,structunicast_client*client){/* 设置目标地址 */msg-addressclient-address;/* 使用transport_sendto发送到特定地址 */returntransport_sendto(p-trp,p-fda,TRANS_EVENT,msg);}配置示例从时钟配置# /etc/linuxptp/ptp4l.conf[global]# 启用单播协商unicast_nego_enabledefault1# 单播主时钟表unicast_master_tabletable1[table1]# 表索引table_id1# 主时钟列表logAnnounceInterval1 logSyncInterval-3logDelayReqInterval-3# 主时钟地址# 格式addressprioritymaster_address192.168.1.100128 master_address192.168.1.101127[eth0]# 使用单播主时钟表unicast_master_tabletable1主时钟配置# /etc/linuxptp/ptp4l.conf[global]# 启用单播服务unicast_nego_enabledefault1# 允许单播请求inhibit_multicast_service0[eth0]# 主时钟优先级priority1128 priority2128启动命令# 从时钟启动ptp4l-ieth0-f/etc/linuxptp/ptp4l.conf-m# 主时钟启动ptp4l-ieth0-m-S# 查看单播状态pmc-uGET UNICAST_MASTER_TABLE_NP单播 vs 组播对比特性组播单播地址224.0.1.129特定IP覆盖范围子网内可跨网段网络负载所有设备接收仅目标接收配置复杂度简单较复杂动态性自动发现需要协商延迟测量E2E或P2PE2E适用场景局域网广域网、跨网段小结单播协商的关键要点核心概念Signaling消息三步握手请求→ 授权 → 传输TLV类型REQUEST_UNICAST_TRANSMISSIONGRANT_UNICAST_TRANSMISSIONCANCEL_UNICAST_TRANSMISSIONACKNOWLEDGE_CANCEL_UNICAST_TRANSMISSION协商参数消息类型发送间隔持续时间适用场景跨网段PTP按需服务精确控制下集预告单播解决了如何建立专线服务但网络中的故障如何诊断下一节我们将分析故障处理与诊断——看看LinuxPTP如何应对各种故障场景。【悬念留给3.13】PTP网络中可能遇到各种故障。如何检测链路故障如何处理主时钟丢失如何诊断同步问题下一节最后一节源码分析。本文内容摘自本人的开源书《PTP技术书 - 从思想实验到协议实现》全书从时间本质的思想实验出发深度解析 IEEE 1588 协议、逐章分析 LinuxPTP 源码并带你动手实现一个轻量级 PTP 程序ptp-lite。 在线阅读/下载ptp-bookgitclone https://github.com/Lularible/ptp-book.git⭐ 如果对您有帮助欢迎 Star 支持也欢迎通过 GitHub Issues 交流讨论。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2567714.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!