一文搞懂SECS/GEM(二)

2024-01-22 03:36
文章标签 一文 搞懂 gem secs

本文主要是介绍一文搞懂SECS/GEM(二),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

继《一文搞懂SECS/GEM(一)》继续补充

这里写目录标题

  • HSMS
    • 2种连接模式(Connect Mode)
    • 6类消息
      • 消息交换过程
        • Select Procedure
        • Data Procedure
        • Deselect Procedure
        • Linktest Procedure
        • Separate Procedure
        • Reject Procedure
    • 4种状态
      • 状态转换
        • Passive Mode(被动模式)连接的状态转换
        • Active Mode(主动模式)连接的状态转换
    • HSMS消息格式
      • 消息格式
      • Message Header一览表
    • 5个计时器

HSMS

HSMS (High-Speed SECS Message Services)属于传输协议标准,描述数据是如何通过物理层在设备与主机之间进行传输的。HSMS定义了使用 TCP/IP 为物理传输媒质时的通信接口。HSMS 可以作为 SECS-I以及其他一些高级通信环境的替代,HSMS 又包括了两个子标准,分别是:

  • HSMS-SS (High-Speed SECS Message Service Single Selected Mode)
  • HSMS-GS (Hiah-Speed SECS Message Service General Session)

HSMS-SS 对母标准中的操进行了简化,以便于实际应用。HSMS-GS 定义了使用 HSMS 访问多个子实体的操作。

HSMS可以使用任何标准 TCP/IP API 进行开发。使用标准的 TCP/IP 寻址,默认的端口号为 5000。

*好,总结一下,其实它就是个TCP通信,只不过它规定了1种消息格式、2种连接模式、4种状态、5个计时器和6种消息类型,通过这些东西完成状态的转化和消息的通信,下文对这些内容做依次讲解

2种连接模式(Connect Mode)

HSMS将通信实体分为两种,Passive Mode(被动模式)和 Active Mode(主动模式)。

  • PassiveMode:处于被动模式的本地实体侦听并接受主动模式的远程实体发起的连接。通常设备在此模式下运行。
  • ActiveMode:主动模式的本地实体发起连接。通常主机(Host)在此模式下运行。

建立连接的过程如下图所示:
在这里插入图片描述
Passive Mode(被动模式)建立连接过程:

  1. 获取一个连接端点,在指定的端口进行监听。
  2. 侦听远程实体发送的连接请求。
  3. 接收连接请求,发送确认。

Active Mode(主动模式)建立连接过程:

  1. 获取一个连接端点。
  2. 向远程实体(被动模式)的端口发起连接。
  3. 等待远程实体接收并返回确认。

6类消息

  • Linktest.req / Linktest.rsp:通信状态确认消息。 如果没有应答则转换为NOT CONNECTED 状态;
  • Select.req / Select.rsp:建立HSMS会话消息。是实体由 NOT SELECTED 状态转换为 SELECTED 状态所使用的消息 ;
  • Deselect.req / Deselect.rsp:”优雅“终止通信消息。在双方协议终止通信时使用,发起通信终止的一端发送Deselect.req,可以记作小情侣和平分手;
  • Separate.req:单方面通信终止消息,可以记作”渣男“终止通信消息。通信某一方单方面通知对方通信终止时发送,不需要对方回复;
  • Recject.req:拒绝消息。在收到无效消息时发送。
  • Data Message:数据消息。只要连接处于SELECTED状态,任何一个实体都可以发起Data Message。当不处于Selected状态时,接收数据消息将导致Reject Procedure。发起者向响应实体发送一条Primary Message。如果Primary Message指示需要响应,则响应实体将发送 Reply Message 响应。

这6类消息细分的话又分成两类,Data Message是数据消息,其他的都是HSMS的控制消息

消息交换过程

Select Procedure

Select Procedure用于在TCP/IP连接上建立HSMS通信。

Select.req和Select.rsp消息:是实体由 Not Selected 状态转换为 Selected 状态所使用的消息 。

在这里插入图片描述

Initiator(发起方)的发起过程:

  1. Initiator将Select.req消息发送给Responding Entity;
  2. 如果Initiator接收到一个Select Status为0的Select.rsp,则Select Procedure过程成功完成,实体由 Not Selected 状态转化为 Selected 状态;
  3. 如果Initiator接收到Select Status不为0的Select.rsp,则Select Procedure失败,实体没有状态转换。

Responding Entity(回应方)的响应过程:

  1. 响应实体会收到Select.req;
  2. 如果响应实体能够转换为Selected ,它将发送一个Select Status为0的Select.rsp;
  3. 如果响应实体不能够转换为Selected,它将发送一个Select Status不为0的Select.rsp;

同时进行的Select Procedure:如果附加标准没有限制,则有可能两个实体同时启动具有相同控制标识的Select Procedure。在这种情况下,每个实体将通过使用Select.rsp响应来接受其他实体的选择请求。

在这里插入图片描述

Data Procedure

只要连接处于Selected状态,任何一个实体都可以发起HSMS数据消息。当不处于Selected状态时,接收数据消息将导致Reject Procedure。

数据消息可以进一步定义为消息事务的一部分,即Primary Message 或 Reply Message。

发起者向响应实体发送一条Primary Message。如果Primary Message指示需要响应,则响应实体将发送 Reply Message 响应。

下图为两种类型的消息事务:

在这里插入图片描述

消息的具体内容由应用层确定,并服从其他标准(例如,使用SECS-II编码消息的GEM设备的E5和E30)。

适用的上层标准由消息类型来标识。该类型由HSMS定义的特定格式确定。HSMS消息的正常类型是SECS-II文本。

Deselect Procedure

Delesect Procedure用于在断开TCP/IP连接之前,为一个实体提供一个优雅的HSMS通信终止;

HSMS要求使用该Procedure时连接处于Selected状态;

Deselect.req/Deselect.rsp在双方协议终止通信时使用,发起通信终止的一端发送Deselect.req。

在这里插入图片描述

Initiator的发起过程:

  1. Initiator将Select.req消息发送给Responding Entity;
  2. 如果Initiator接收到一个Select Status为0的Select.rsp,则Select Procedure过程成功完成,实体由 Not Selected 状态转化为 Selected 状态;
  3. 如果Initiator接收到Select Status不为0的Select.rsp,则Select Procedure失败,实体没有状态转换。

Responding Entity的响应过程:

  1. 响应实体会收到Select.req;
  2. 如果响应实体能够转换为Selected ,它将发送一个Select Status为0的Select.rsp;
  3. 如果响应实体不能够转换为Selected,它将发送一个Select Status不为0的Select.rsp;

同时进行的Select Procedure:如果附加标准没有限制,则有可能两个实体同时启动具有相同控制标识的Select Procedure。在这种情况下,每个实体将通过使用Select.rsp响应来接受其他实体的选择请求。

在这里插入图片描述

Linktest Procedure

Linktest Procedure 用于确定TCP/IP和HSMS通信的完整性。只要连接处于Selected状态,可以随时使用。

Linktest.req/Linktest.rsp:用于通信状态的确认, 如果没有应答则转换为Not Connected 状态;

在这里插入图片描述

Initiator的发起过程:

  1. Initiator将Linktest.req消息发送给Responding Entity;
  2. 如果Initiator在T6超时时间内接收到一个Linktest.rsp,Linktest Procedure成功完成;
  3. 如果在T6超时时间内未收到Linktest.rsp,则视为通信故障。

Responding Entity的响应过程:

  1. 响应实体接收到Linktest.req;
  2. 响应实体发送Linktest.rsp。
Separate Procedure

Separate Producure用于在断开TCP/IP连接之前突然终止实体的HSMS通信。

HSMS要求使用该Procedure时连接处于Selected状态。

Separate.req:在单方面通知通信终止时发送;

在这里插入图片描述

Reject Procedure

Reject Procedure用于响应在不适当的上下文中收到的其他有效的HSMS消息,即接收到消息的接收方不支持该消息或认为无效的消息;

Recject.req:在收到无效消息时发送。

在这里插入图片描述

4种状态

在这里插入图片描述

状态说明:

  • NOT CONNECTED:开始监听,但尚未建立任何连接或以前建立的TCP/IP连接都已终止;

  • CONNECTED:已建立了一个TCP/IP连接。此状态有两个子状态——NOT SELECTED 和 SELECTED;

    • NOT SELECTED:没有建立HSMS会话或先前建立的HSMS会话已结束;

    • SELECTED:至少建立了一个HSMS会话,这是HSMS的通常状态,数据消息可以在此状态下进行交换。

状态转换

在这里插入图片描述

Passive Mode(被动模式)连接的状态转换

在这里插入图片描述

Active Mode(主动模式)连接的状态转换

在这里插入图片描述

HSMS消息格式

消息格式

在这里插入图片描述

  • Message Length:一个4字节的无符号整数,表示其后Message Header加上Message Text的总字节数,其最小值为10字节。

  • Message Header:消息头的长度固定为10字节,格式如下图所示:

    0upper Session ID
    1lower Session ID
    2Header Byte 2
    3Header Byte 3
    4PType
    5SType
    6~9System Bytes
    • Session ID:又叫Device ID,是16位无符号整数。用于标识通信实体的连接;此外,对于有回复的消息,ReplyMessage 的 Session ID 应与其对应回复的PrymaryMessage的Session ID相同。

    • Header Byte 2:对于不同的HSMS消息,有不同的取值,参考如下表格:

      消息类型Header Byte 2说明
      Data MessageW-bit and
      SECS Stream
      DataMeaages的Head Byte2由高1位的W-bit和低7位的SECS Stream组成。
      W-Bit:指示Primary Message是否需要Reply Message,期望应答则设置为1,不期望应答则设置为0。Reply Message应该始终将W-bit设置为0。
      SECS Stream:是一个7位无符号整数值,位于低阶7位(第6-0位)。SECS Stream表示消息的一个主题,它的使用在SEMIE5(SECS-II)中定义。
      Select.req0
      Select.rsp0
      Deselect.req0
      Deselect.rsp0
      Linktest.req0
      Linktest.rsp0
      Reject.reqPType or SType如果不支持PType,该位设置成被拒绝的消息的PType。否则,设置成被拒绝的消息中的SType的值
      Separate.req0
    • Header Byte 3:对于不同的HSMS消息,有不同的取值,参考如下表格:

      消息类型Header Byte 3说明
      Data MessageSECS FunctionSECS Function:功能是一个8位的无符号整数值,用于标识消息的一个次要话题,偶数是Primary消息,奇数是Replay消息。它的使用以及和Stream的关系在SEMIE5(SECS-II)中定义。
      Select.req0
      Select.rspSeclect Status0 - Select操作成功;
      1 - 通信已激活。之前的Select已经操作成功过了
      2 - 连接未就绪。连接尚未准备好接受Select请求。
      3 - 连接已用光。该连接已被接受,但该实体已在为一个单独的TCP/IP连接提供服务,并且无法在任何给定时间为多个连接提供服务。
      4~127 - 子标准保留
      128~255 - 保留,未使用
      Deselect.req0
      Deselect.rspDeseclect Status0 - 通信结束,Deselect操作成功
      1 - 通信未建立。HSMS通信尚未通过选择建立,或先前Deselect已经操作成功过了。
      2 - 通信繁忙。会话仍在由响应实体使用,因此它还不能优雅地放弃会话。在这种情况下,如果请求者一定要终止通信的话,则应使用Separate.req。
      3~127 - 子标准保留
      128~255 - 保留,未使用
      Linktest.req0
      Linktest.rsp0
      Reject.reqReason Code1 - 收到的SType不支持
      2 - 收到的PType不支持
      3 - 交易未打开。当没有对应的未处理的请求消息时,收到响应控制消息。例如:发送方发送了Select.req后,收到了两条Select.rsp,对于第一条Select.rsp正常处理,对于第二条Select.rsp就回应Reject.req,Reason Code为3
      4 - 未处于SELECTED状态时收到一条数据消息
      5~127 - 子标准保留
      128~255 - 保留,未使用
      Separate.req0
    • PType:表示类型(Presentation Type),8位无符号整型,使用枚举表示层消息类型,即MessageHeader和MessageText是如何编码的,取值如下:

      取值描述
      0SECS-II 编码
      1~127子标准保留
      128~255保留,未使用
    • SType:会话类型(Session Type),8位无符号整数,表示此消息是何类消息,取值类型如下表:

      取值描述
      0Data Message
      1Select.req
      2Select.rsp
      3Deselect.req
      4Deselect.rsp
      5Linktest.req
      6Linktest.rsp
      7Reject.req
      8未使用
      9Separate.req
      10未使用
      11~127子标准保留
      128~255保留,未使用
    • System Bytes:四字节无符号整数,用于唯一标识一次消息交互,一定要具备唯一性。此外,ReplyMessage 的 SystemBytes 应与其对应回复的PrymaryMessage的SystemBytes相同。

  • Message Test:消息文本。格式由Message Header的PType字段决定。

Message Header一览表

下表总结了6种消息的Message Header(清晰明了,重点看一下!)如下:

在这里插入图片描述

5个计时器

计时器名字范围建议值描述
T3回复超时(Reply Timeout)1~120s45s一个实体等待回复消息的最长时间,如果T3超时则取消这次会话事务但不断开 TCP/IP 连接
T5连接间隔时间(Connect SeparationTimeout)1~240s10s定义两个连接请求之间的时间间隔。
频繁的向一个未准备好连接的实体发起连接请求,会加重 TCP/IP 的操作负荷。因此,当一个主动模式实体发起的连接操作终止后(不论是成功结束还是被远端实体拒绝),该实体必须等待 T5 时间再后发起下一次连接请求。
T6控制会话超时(Transaction Timeout)1~240s5s定义了一个控制事务所能保持开启的最长时间,超过该时间就认为这次通信失败。
当发送.req控制信息时T6计时器开启,若在T6超时之前收到了响应的.rsp消息则计时器关闭,否则控制消息的发起者将关闭这次会话,并认为出现一个通信故障
T7Not Select状态超时(Not Select Timeout)1~240s10s表示当建立了 TCP/IP 连接之后通信处于 Not Selected 状态的最长时间,通信必须在该时间完成 Selecte操作,否则将会断开 TCP/IP 连接
T8网络字符超时(Network Intercharacter Timeout)1~120s5s表示成功接收到单个HSMS消息的字符之间的最大时间间隔。由于TCP/IP时面向流的通信协议,因此一个HSMS通信消息可能被分为若干个TCP/IP消息进行传送,若T8计时器超时则认为这次传输失败。

注:计时器数值的最小分辨率是1秒,不能使用小数




以上这些,基于工作经验和SECS标准手册整理而来,由问题和纰漏请多多指正,感谢~~~

这篇关于一文搞懂SECS/GEM(二)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

一文带你理解Python中import机制与importlib的妙用

《一文带你理解Python中import机制与importlib的妙用》在Python编程的世界里,import语句是开发者最常用的工具之一,它就像一把钥匙,打开了通往各种功能和库的大门,下面就跟随小... 目录一、python import机制概述1.1 import语句的基本用法1.2 模块缓存机制1.

一文带你搞懂Nginx中的配置文件

《一文带你搞懂Nginx中的配置文件》Nginx(发音为“engine-x”)是一款高性能的Web服务器、反向代理服务器和负载均衡器,广泛应用于全球各类网站和应用中,下面就跟随小编一起来了解下如何... 目录摘要一、Nginx 配置文件结构概述二、全局配置(Global Configuration)1. w

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

CSP-J基础之数学基础 初等数论 一篇搞懂(一)

文章目录 前言声明初等数论是什么初等数论历史1. **古代时期**2. **中世纪时期**3. **文艺复兴与近代**4. **现代时期** 整数的整除性约数什么样的整数除什么样的整数才能得到整数?条件:举例说明:一般化: 判断两个数能否被整除 因数与倍数质数与复合数使用开根号法判定质数哥德巴赫猜想最大公因数与辗转相除法计算最大公因数的常用方法:举几个例子:例子 1: 计算 12 和 18

CSP-J基础之数学基础 初等数论 一篇搞懂(二)

文章目录 前言算术基本定理简介什么是质数?举个简单例子:重要的结论:算术基本定理公式解释:举例: 算术基本定理的求法如何找出质因数:举个简单的例子: 重要的步骤:C++实现 同余举个例子:同余的性质简介1. 同余的自反性2. 同余的对称性3. 同余的传递性4. 同余的加法性质5. 同余的乘法性质 推论 总结 前言 在计算机科学和数学中,初等数论是一个重要的基础领域,涉及到整数

Post-Training有多重要?一文带你了解全部细节

1. 简介 随着LLM学界和工业界日新月异的发展,不仅预训练所用的算力和数据正在疯狂内卷,后训练(post-training)的对齐和微调方法也在不断更新。InstructGPT、WebGPT等较早发布的模型使用标准RLHF方法,其中的数据管理风格和规模似乎已经过时。近来,Meta、谷歌和英伟达等AI巨头纷纷发布开源模型,附带发布详尽的论文或报告,包括Llama 3.1、Nemotron 340

一文说清什么是AI原生(AI Native)应用以及特点

引言:智能新纪元 如今,走在街头,哪儿不被智能科技包围?智能音箱、自动驾驶汽车、聊天机器人......这些都在用不同的方式提升我们的生活体验。然而,究竟什么才能称得上“AI原生应用”呢? 什么是AI原生?   AI原生不仅仅是简单地引入人工智能功能。真正的AI原生应用犹如一个智慧的“大脑”,它的每一个决策都依赖于深度学习与数据分析。以Siri为例,它通过学习用户的习惯和需求,提供个性化的

世界公认十大护眼灯数据出炉!一文看懂孩子用的台灯哪个牌子好

近年来,随着科技的迅猛发展,诸如智能手机、电脑等电子设备在工作、学习及娱乐中的应用日益广泛,人们对这些设备的依赖程度也随之加深。然而,长时间面对屏幕不可避免地给眼睛带来伤害,如眼疲劳、干燥甚至近视等问题。因此,市场对能够缓解眼疲劳的照明产品的需求日益增长。这类护眼照明产品通常采用无频闪、无紫外线辐射等技术,旨在减少对眼睛的潜在危害,有效保护视力健康,并降低眼疾的发生率。随着护眼台灯的不断创新进步,

一文详解go底层原理之垃圾回收

1 前置知识 1.1 三色回收法 三色回收法在gov1.5版本时是主流的gc方式 简单介绍一下流程: 暂停程序执行流程(开启STW)将新创建的对象全部标记为白色从根节点开始遍历,把遍历到的第一层全部改为灰色遍历一次灰色集合,将灰色集合引用对象变为黑色重复上述步骤,知道没有灰色对象清除白色对象结束STW 1.2 STW 上述1.1所说的STW就是指的stop the world,简单的说

Apache Spark3.0什么样?一文读懂Apache Spark最新技术发展与展望

简介: 阿里巴巴高级技术专家李呈祥带来了《Apache Spark 最新技术发展和3.0+ 展望》的全面解析,为大家介绍了Spark在整体IT基础设施上云背景下的新挑战和最新技术进展,同时预测了Spark 3.0即将重磅发布的新功能。 2019阿里云峰会·上海开发者大会于7月24日盛大开幕,在本次峰会的开源大数据专场上,阿里巴巴高级技术专家李呈祥带来了《Apache Spark 最新技术发展和