DZ先生怪谈国标28181之目录订阅与通知

您所在的位置:网站首页 下级回复上级通知 DZ先生怪谈国标28181之目录订阅与通知

DZ先生怪谈国标28181之目录订阅与通知

2024-07-11 22:46| 来源: 网络整理| 查看: 265

1. 自述

今日DZ先生主要讲的课题是:目录订阅和通知

2. 订阅的作用

有人肯定会问,这个订阅是干嘛用的,简单点来讲就是保持上下级域之间的目录结构,设备状态保持一致。举个小例子:这边有两台sip服务器A和B,A和B通过国标对接,A把资源推送给B,B订阅A域的系统ID,A上的一个摄像头原来在线的,现在离线了,那么A就会通知B,我这儿有个摄像头离线了,然后B也让A推送过来的这个摄像头离线,此外每当A上的设备离线,上线,增加,删除,目录更新时,都会向B发送通知哦!好了小伙伴们,通过这个小例子,你明白他的作用没?

3. 订阅方式(详细见IETF RFC 3265)

小伙伴们根据你的工作经验,你认为A域订阅B域,有几种订阅方式?

根据DZ君的工作经验,目前DZ君只遇到了A域订阅B域的系统ID,因为DZ君遇到的平台还不可以订阅下级域的目录,也没有操作过其他的订阅方式。

没关系,那就跟DZ君一起学习下国标28181-2016里的定义吧,咱一起学习一起进步。

国标标准定义了以下几种订阅方式:

1)A订阅B的系统ID------最常用的

    释:B 域检测到直属目录和下级域的目录变更事件时应向 A 域发送通知消息;

2)A订阅B的下级域系统ID

    释:B 域检测到对应此ID 的下级系统范围内的目录变更事件时应向 A 域发送通知消息;

3)A订阅B的行政区划编码

    释:B 域检测到属于此行政区划的目录变更事件时应向 A 域发送通知消息

4)A订阅B的设备ID

    释:B 域检测到该设备及其下属子设备发生目录变更事件时应向A 域发送通知消息;

5)A订阅B的上报业务分组ID,虚拟组织ID

    释:B 域检测到该业务分组、 虚拟组织下属虚拟组织、 设备发生目录变更事件时应向 A 域发送通知消息 

4. 刷新订阅

    A 域在初始订阅成功之后, 应在过期之前向 B 域发送刷新订阅消息, 进行订阅状态维护。

    刷新订阅消息与初始订阅消息属于同一会话, 并且 Expire 头域值大于0. 

    初始化订阅时,Expire头域值国标定义可以配置,默认为600s。

5. 取消订阅(两种方式:主动和被动)

    主动: A订阅B,A主动取消订阅。取消订阅请求应与初始订阅请求属于同一会话, 并且 Expire 头域值为0

    被动: A订阅B,B 域可通过发送subscription-state 头域为terminated 的 NOTIFY 消息主动结束订阅, NOTIFY

               消息体可为空, 订阅方接收到该消息后回复200 OK 响应。

6. 信令流程

 

命令流程描述如下:1: 订阅域向被订阅域发送初始订阅SUBSCRIBE 消息, 订阅目的域的目录变更事件, 消息头域中使用 Event 头域描述订阅事件, 消息体中携带订阅的详细参数, 使用 Expire 头域指定订阅过期时间; 2: 被订阅域设备收到订阅消息后, 向订阅域发送200 OK 响应; 3: 对于初始订阅操作, 被订阅域立即发送 NOTIFY 消息携带离线及其他异常状态设备目录,消息头域中使用 Event 头域描述订      阅事件;

4: 订阅域收到 NOTIFY 消息后回复200 OK 响应;

5: 被订阅域目录变更后, 通过 NOTIFY 消息将变更事件通知订阅域, 消息头域中使用 Event头域描述订阅事件;

 

6: 订阅域收到 NOTIFY 消息后回复200 OK 响应; 7: 订阅域在过期之前向被订阅域发送刷新订阅 SUBSCRIBE 消息, 订阅目的域的目录变更事件, 消息头域中使用 Event 头域描述订     阅事件, 消息体中携带订阅的详细参数, 使用 Expire 头域指定订阅过期时间; 8: 被订阅域设备收到订阅消息后, 向订阅域发送200 OK 响应; 9: 被订阅域目录变更后, 通过 NOTIFY 消息将变更事件通知订阅域, 消息头域中使用 Event头域描述订阅事件; 10: 订阅域收到 NOTIFY 消息后回复200 OK 响应; 11: 订阅域向被订阅域发送取消订阅SUBSCRIBE 消息, 消息头域中使用 Event 头域描述订阅事件, 消息体中携带订阅的详细参数,Expire 头域值为0;

 

12: 被订阅域设备收到订阅消息后, 向订阅域发送200 OK 响应, 取消向订阅域发送目录变更通知消息。

7. 实例分析

第一步:SUBSCRIBE消息

第三步:NOTIFY消息,初始订阅上报离线及异常设备状态

 

第五步: NOTIFY消息暂时没抓,后期补上

第七步:刷新订阅是比较难抓的,有机会抓来展示

第九步:后期补上

第11步:来看下主动取消吧,被动取消有机会可以的话,补上,因为DZ在做的时候是先取消的订阅,在订阅的,所以这边的CALL-id和订阅的CALL-ID不一致

 

8.订阅消息与通知消息体(国标规范)

订阅消息消息体示例如下: < ? xml version="1.0" ?> < ! -- 命令类型: 目录订阅(必选) --> Catalog < ! -- 命令序列号(必选) --> 命令序列号 < ! -- 订阅的系统/行政区划/设备/业务分组/虚拟组织编码(必选) --> 订阅编码

通知消息消息体示例如下, 增加/更新目录通知消息中Item 的字段参数应遵循 A.2.1g) 的规定: < ? xml version="1.0" ?> < ! -- 命令类型: 目录订阅(必选) --> Catalog < ! -- 命令序列号(必选) --> 命令序列号 < ! -- 订阅的系统/行政区划/设备/业务分组/虚拟组织编码(必选) --> 订阅编码 < ! -- 通知消息中SumNum 取值与 DeviceList 中 Num 取值相同(必选) --> 2

 

 

< ! -- 状态改变的系统/设备/行政区划编码(必选) --> 编码1 < ! -- 状态改变事件 ON: 上线, OFF: 离线, VLOST: 视频丢失,DEFECT: 故障, ADD: 增加,DEL: 删除,UPDATE: 更新(必选) --> OFF

 

 

 

< ! -- 状态改变的系统/设备/行政区划编码(必选) --> 编码n < ! -- 状态改变事件 ON: 上线, OFF: 离线, VLOST: 视频丢失,DEFECT: 故障, ADD: 增加,DEL: 删除,UPDATE: 更新(必选) --> ADD IPC_天山视频 < Manufacturer>XXX < Model>1.0 0 650102 axy 0 1 0 ON



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3