CN108737006A - 一种时间同步方法、客户端及计算机可读存储介质 - Google Patents
一种时间同步方法、客户端及计算机可读存储介质 Download PDFInfo
- Publication number
- CN108737006A CN108737006A CN201810543013.1A CN201810543013A CN108737006A CN 108737006 A CN108737006 A CN 108737006A CN 201810543013 A CN201810543013 A CN 201810543013A CN 108737006 A CN108737006 A CN 108737006A
- Authority
- CN
- China
- Prior art keywords
- time
- client
- server
- message
- receiving
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04J—MULTIPLEX COMMUNICATION
- H04J3/00—Time-division multiplex systems
- H04J3/02—Details
- H04J3/06—Synchronising arrangements
- H04J3/0635—Clock or time synchronisation in a network
- H04J3/0638—Clock or time synchronisation among nodes; Internode synchronisation
- H04J3/0658—Clock or time synchronisation among packet nodes
- H04J3/0661—Clock or time synchronisation among packet nodes using timestamps
- H04J3/0667—Bidirectional timestamps, e.g. NTP or PTP for compensation of clock drift and for compensation of propagation delays
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
- Synchronisation In Digital Transmission Systems (AREA)
- Computer And Data Communications (AREA)
Abstract
本发明实施例公开了一种时间同步方法、客户端及计算机可读存储介质,应用于客户端,客户端上设置硬件电路,客户端通过硬件电路与服务器进行数据交互,该方法包括:利用客户端程序得到时间同步请求报文;当通过硬件电路将时间同步请求报文发送至服务器时,利用硬件电路获取第一发送时间;将第一发送时间添加至时间同步请求报文,以完成将时间同步请求报文发送至服务器的过程;当通过硬件电路从服务器接收到时间同步响应报文时,利用硬件电路获取第一接收时间;根据第一发送时间、第一接收时间和预设同步算法,计算出客户端与服务器之间的时间差值;以利用时间差值完成客户端与服务器之间的时间同步的过程。
Description
技术领域
本发明涉及通信领域,尤其涉及一种时间同步方法、客户端及计算机可读存储介质。
背景技术
简单网络时间协议(SNTP,Simple Network Protocol)是一种跨广域网或局域网同步时间的协议,具有较高的精确度,SNTP采用的是客户端/服务器的工作方式,包括以太网单播模式和广播模式。其中,单播模式为客户端定期直接与SNTP服务器进行交互来获取时间差进行时间校正,具体的,如图1所示,SNTP客户端利用客户端程序将发送时间T1时刻写入SNTP同步请求报文,并在T1'时刻通过硬件电路将SNTP同步请求报文发送至SNTP服务器,SNTP服务器在T2时刻接收到SNTP客户端发送的SNTP同步请求报文,并在T3时刻将响应SNTP同步请求报文的SNTP同步响应报文发送至SNTP客户端,SNTP客户端的硬件电路在T4'时刻接收到SNTP同步响应报文之后,利用客户端程序获取T4时刻作为接收时间,最后,SNTP客户端利用T1、T2、T3和T4计算SNTP客户端和SNTP服务器之间的时间差值,从而对SNTP客户端进行时间校正。
然而,利用客户端程序等软件方式获取的T1和SNTP客户端真正发出同步请求的时间T1'之间存在T1-T1'的时间差,利用软件方式获取的T4和SNTP客户端真正接收到同步响应的时间T4'之间存在T4-T4'的时间差,导致利用T1、T2、T3和T4计算SNTP客户端和SNTP服务器之间的时间差值时,得到的时间差值存在误差,从而影响了SNTP客户端的对时精度。
发明内容
为解决上述技术问题,本发明实施例期望提供一种时间同步方法、客户端及计算机可读存储介质,能够降低计算客户端和服务器之间的时间差值时的计算误差,提高客户端的对时精度。
本发明的技术方案是这样实现的:
本发明实施例提供一种时间同步方法,应用于客户端,所述客户端上设置硬件电路,所述客户端通过所述硬件电路与服务器进行数据交互,所述方法包括:
利用客户端程序得到时间同步请求报文;
当通过所述硬件电路将所述时间同步请求报文发送至所述服务器时,利用所述硬件电路获取第一发送时间;
将所述第一发送时间添加至所述时间同步请求报文,以完成将所述时间同步请求报文发送至所述服务器的过程;
当通过所述硬件电路从所述服务器接收到时间同步响应报文时,利用所述硬件电路获取第一接收时间,所述时间同步响应报文为响应所述时间同步请求报文的报文;
根据所述第一发送时间、第一接收时间和预设同步算法,以利用所述时间差值完成所述客户端和所述服务器之间的时间同步的过程。
在上述方法中,所述时间同步响应报文包括第二接收时间和第二发送时间,所述第二接收时间为所述服务器接收到所述时间同步请求报文的时间,所述第二发送时间为所述服务器发送所述时间同步响应报文的时间,所述根据所述第一发送时间、第一接收时间和预设同步算法,计算出所述客户端与所述服务器之间的时间差值,包括:
利用所述第一发送时间、所述第一接收时间、所述第二发送时间、所述第二接收时间和所述预设同步算法,计算出所述时间差值。
在上述方法中,所述利用所述第一发送时间、所述第一接收时间、所述第二发送时间、所述第二接收时间和所述预设同步算法,计算出所述时间差值,包括:
分别获取所述第二接收时间和所述第一发送时间的第一时间差、所述第一接收时间和所述第二发送时间的第二时间差;
计算出所述第一时间差和所述第二时间差的平均值;
将所述平均值确定为所述时间差值。
在上述方法中,所述当通过所述硬件电路将所述时间同步请求报文发送至所述服务器时,利用所述硬件电路获取第一发送时间,包括:
将所述时间同步请求报文封装成第一报文帧;
通过所述硬件电路将所述第一报文帧发送至所述服务器;
当通过所述硬件电路检测到所述第一报文帧中的第一帧起始符时,获取所述第一发送时间;
相应的,所述将所述第一发送时间添加至所述时间同步请求报文,包括:
在所述第一报文帧添加所述第一发送时间。
在上述方法中,所述利用所述硬件电路获取第一接收时间,包括:
从所述服务器接收第二报文帧;
在通过所述硬件电路检测到所述第二报文帧的第二起始符时,获取所述第一接收时间。
在上述方法中,所述利用所述硬件电路获取第一接收时间之后,所述根据所述第一发送时间、第一接收时间和预设同步算法,计算出所述客户端与所述服务器之间的时间差值之前,所述方法还包括:
将所述第一接收时间添加至所述第二报文帧中;
将所述第二报文帧解封成所述时间同步响应报文;
从所述时间同步响应报文中获取所述第一发送时间、所述第一接收时间、所述第二发送时间和所述第二接收时间。
本发明实施例提供一种客户端,所述客户端与服务器进行数据交互,所述客户端包括:
处理器,所述处理器设置有第一通信接口;
与所述处理器通过所述第一通信接口和第二通信接口连接的硬件电路,所述硬件电路上设置有所述第二通信接口和第三通信接口,所述硬件电路通过所述第三通信接口与所述服务器连接;其中,
所述处理器,用于当运行客户端程序得到时间同步请求报文时,将所述时间同步请求报文传输至所述硬件电路;
所述硬件电路,用于当将所述时间同步请求报文发送至所述服务器时,获取第一发送时间;当从所述服务器接收到响应所述时间同步请求报文的时间同步响应报文时,获取第一接收时间,并将所述第一发送时间和所述第一接收时间传输至所述处理器;
所述处理器,还用于利用所述第一发送时间、所述第一接收时间和预设同步算法,计算出所述客户端与所述服务器之间的时间差值;以利用所述时间差值完成所述客户端和所述服务器之间的时间同步的过程。
在上述客户端中,所述硬件电路,具体用于将所述第一发送时间添加至所述时间同步请求报文中,并将所述时间同步请求报文发送至所述服务器;
所述硬件电路,具体用于将所述第一接收时间添加至所述时间同步响应报文,并将所述时间同步响应报文传输至所述处理器,以将所述第一发送时间和所述第一接收时间传输至所述处理器。
在上述客户端中,所述时间同步响应报文包括第二接收时间和第二发送时间,所述第二接收时间为所述服务器接收到所述时间同步请求报文的时间,所述第二发送时间为所述服务器发送所述时间同步请求报文的时间;
所述处理器,具体用于利用所述第一发送时间、所述第一接收时间、所述第二发送时间、所述第二接收时间和所述预设同步算法,得到时间差值。
在上述客户端中,所述处理器,具体用于分别获取所述第二接收时间和所述第一发送时间的第一时间差、所述第一接收时间和所述第二发送时间的第二时间差;计算出所述第一时间差和所述第二时间差的平均值,将所述平均值确定为所述时间差值。
在上述客户端中,所述硬件电路,还用于将所述时间同步请求报文封装成第一报文帧,将所述第一报文帧发送至所述服务器;从所述服务器接收第二报文帧,并将所述第二报文帧解封成所述时间同步响应报文。
在上述客户端中,所述硬件电路,具体用于当检测到所述第一报文帧的第一帧起始符时,获取所述第一发送时间;在所述第一报文帧添加所述第一发送时间;将所述第一报文帧发送至所述服务器;
所述硬件电路,具体用于当检测到所述第二报文帧的第二帧起始符时,获取所述第一接收时间;将所述第一接收时间添加至所述第二报文帧中;
所述处理器,还用于将所述第二报文帧解封成所述时间同步响应报文;从所述时间同步响应报文中获取所述第一发送时间、所述第一接收时间、所述第二发送时间和所述第二接收时间。
本发明实施例提供一种计算机可读存储介质,其上存储有计算机程序,应用于客户端中,该计算机程序被的处理器执行时实现如上述任一项所述时间同步的方法。
本发明实施例公开了一种时间同步方法、客户端及计算机可读存储介质,应用于客户端,客户端上设置硬件电路,客户端通过硬件电路与服务器进行数据交互,利用客户端程序得到时间同步请求报文;当通过硬件电路将时间同步请求报文发送至服务器时,利用硬件电路获取第一发送时间;将第一发送时间添加至时间同步请求报文,以完成将时间同步请求报文发送至服务器的过程;当通过硬件电路从服务器接收到时间同步响应报文时,利用硬件电路获取第一接收时间,时间同步响应报文为响应时间同步请求报文的报文;根据第一发送时间、第一接收时间和预设同步算法,计算出客户端与服务器之间的时间差值;以利用时间差值完成客户端与服务器之间的时间同步的过程。采用上述技术实现方案,当硬件电路检测到向服务器发送的时间同步请求报文时,硬件电路获取第一发送时间;当硬件电路检测到服务器发送的时间同步响应报文时,直接获取第一接收时间,使得客户端获取到的第一发送时间更接近真正的时间同步请求报文的发出时间、第一接收时间更接近真正的时间同步响应报文的接收时间,故,客户端利用第一发送时间和第一接收时间计算时间差值时,能够降低计算误差,进而提高客户端的对时精度。
附图说明
图1为现有技术中时间同步的示意图;
图2为本发明实施例提供的一种SNTP对时报文的报文格式;
图3为本发明实施例提供的一种时间同步方法的流程图;
图4为本发明实施例提供的一种示例性的FPGA获取第一发送时间的获取时机的示意图;
图5为本发明实施例提供的一种示例性的FPGA获取第一接收时间的获取时机的示意图;
图6为本发明实施例提供的一种时间同步方法的交互图;
图7为本发明实施例提供的一种时间同步的示意图;
图8为本发明实施例提供的一种客户端的结构示意图;
图9为本发明实施例提供的一种示例性的SNTP客户端和SNTP服务器之间的连接关系图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述。
SNTP对时报文格式如图2所示,其中各个字段的含义为:
L1为跳跃指示器;
VN为版本号;
Mode为工作模式,该字段包括以下值:0-预留;1-对称行为;3-客户机;4-服务器;5-广播;6-NTP控制信息;
Stratum:对本地市中级别的整体识别;
Poll:有符号整数表示连续信息间的最大间隔;
Precision:有符号整数表示联系信息间的最大间隔;
Root Delay:表示到达主参考源的依次往复的总延时,它是有15-16位小数部分的符号定点小数;
Root Dispersion:表示一次到达主参考源的标准误差,它是有15-16位小数部分的无符号定点小数;
Reference ID:识别特殊参考源;
Originate Timestamp:这是向服务器请求分离客户机的时间,采用64位时标格式;
Receive Timestamp:这是向服务器请求到达客户机的时间,采用64位时标格式;
Transmit Timestamp:这是向客户机答复分离服务器的时间,采用64位时标格式;
Destination Timestamp:这是到达客户机的时间,采用64为时标格式;
Authenticator(Optical):当实现了NTP认证模式时,主要标示符和信息数字域就包括已定义的信息认证代码(MAC)信息。
实施例一
本发明实施例提供一种时间同步方法,应用于客户端,客户端包括设置有第一通信接口的硬件电路,客户端通过第一通信接口与服务器进行数据交互,如图3所示,该方法可以包括:
S101、利用客户端程序得到时间同步请求报文。
本发明实施例提供的一种时间同步方法适用于将客户端的时间同步为与服务器时间一致的场景下。
本发明实施例中,客户端为SNTP客户端、与客户端进行数据交互的服务器为SNTP服务器。
本发明实施例中,硬件电路为现场可编程门阵列(FPGA,Field-ProgrammableGate Array)等,具体的根据实际情况进行选择,本发明实施例不做具体的限定。
本发明实施例中,处理器为中央处理器(CPU,Central Processing Unit),具体的根据实际情况进行选择,本发明实施例不做具体的限定。
本发明实施例中,SNTP客户端的CPU运行客户端程序,得到SNTP对时请求报文(时间同步请求报文),其中,CPU上设置有介质访问控制子层(MAC,Media Access Control)接口,FPGA上设置有与CPU配对的MAC接口,CPU和FPGA通过MAC接口进行MAC直连。
S102、当通过硬件电路将时间同步请求报文发送至服务器时,利用硬件电路获取第一发送时间。
当客户端利用客户端程序得到时间同步请求报文时,硬件电路检测时间同步请求报文是否发送至服务器,当硬件电路检测到客户端将时间同步请求报文发送至服务器时,硬件电路获取第一发送时间。
本发明实施例中,硬件电路上设置有以太网接口(第一通信接口),SNTP服务器上也设置有以太网接口,硬件电路和SNTP服务器通过以太网接口连接,并进行数据交互。
本发明实施例中,CPU将SNTP对时请求报文通过MAC接口传输至FPGA,此时,当FPGA将SNTP对时请求报文发送至SNTP服务器时,FPGA获取第一发送时间。
本发明实施例中,SNTP客户端和SNTP服务器之间传输的是数据帧,故,SNTP客户端和SNTP服务器在发送SNTP对时报文时,是以以太网报文帧的格式进行发送的。
本发明实施例中,SNTP客户端将时间同步请求报文封装成第一报文帧,并通过FPGA将第一报文帧发送至SNTP服务器,其中,第一报文帧的发送顺序为以太网前导码、以太网帧开始分界符和以太网报文,FPGA在检测到传输以太网帧开始分界符时,获取第一发送时间。
S103、将第一发送时间添加至时间同步请求报文,以完成将时间同步请求报文发送至服务器的过程。
当硬件电路获取到第一发送时间之后,硬件电路就要将第一发送时间添加至时间同步请求报文,以完成将时间同步请求报文发送至服务器的过程了。
本发明实施例中,SNTP客户端将第一发送时间填入SNTP对时请求报文的Originate Timestamp字段中,之后继续将第一报文帧发送至SNTP服务器。
示例性的,如图4所示,SNTP客户端发送SNTP对时请求报文帧的发送顺序为以太网前导码、以太网帧开始分界符和以太网报文,FPGA在检测到传输以太网帧开始分界符时,获取系统时间,并将该系统时间填入SNTP对时请求报文的Originate Timestamp字段中。
S104、当通过硬件电路从服务器接收到时间同步响应报文时,利用硬件电路获取第一接收时间,时间同步响应报文为响应时间同步请求报文的报文。
当客户端通过硬件电路将时间同步请求报文发送至服务器之后,客户端就要通过硬件电路实时接收服务器发送的时间同步响应报文了,当通过硬件电路从服务器接收到时间同步响应报文时,客户端利用硬件电路获取第一接收时间。
本发明实施例中,SNTP服务器在接收到SNTP对时请求报文时,获取第二接收时间,并将第二接收时间添加至SNTP对时请求报文的Receive Timestamp字段中,之后SNTP服务器获取本地时钟信息(第二发送时间),填入SNTP对时请求报文的Transmit Timestamp字段中,得到SNTP对时响应报文(时间同步响应报文),并将SNTP对时响应报文通过以太网接口发送至SNTP客户端中。
本发明实施例中,当FPGA接收到SNTP对时响应报文对应的第二报文帧时,FPGA的接收顺序为以太网前导码、以太网帧开始分界符和以太网报文,FPGA在接收到以太网帧开始分界符时,获取第一接收时间,并将该第一接收时间填入SNTP对时响应报文的Destination Timestamp字段中。
示例性的,如图5所示,SNTP客户端接收到SNTP对时响应报文帧的接收顺序为以太网前导码、以太网帧开始分界符和以太网报文,FPGA在接收到以太网帧开始分界符时,获取系统时间,并将该系统时间填入SNTP对时响应报文的Destination Timestamp字段中。
本发明实施例中,FPGA将SNTP对时响应报文传输至CPU,此时CPU从SNTP对时响应报文中确定出第一发送时间、第一接收时间、第二发送时间和第二接收时间。
S105、根据第一发送时间、第一接收时间和预设同步算法,计算出客户端与服务器之间的时间差值,以利用时间差值完成客户端和服务器之间的时间同步的过程。
当客户端利用硬件电路获取到第一发送时间和第一接收时间时,客户端就要根据第一发送时间、第一接收时间和预设同步算法,计算出客户端与服务器之间的时间差值,并利用时间差值完成客户端和服务器之间的时间同步的过程了。
本发明实施例中,CPU根据第一发送时间、第一接收时间、第二发送时间和第二接收时间来计算时间差值。
本发明实施例中,CPU分别获取第二接收时间和第一发送时间的第一时间差、和第一接收时间和第二发送时间的第二时间差,之后,计算第一时间差和第二时间差的平均值,并将平均值确定为时间差值。
具体的,预设同步算法为:
((T2-T1)+(T3-T4))/2(1)
其中,T1为第一发送时间,T2为第二接收时间,T3为第二发送时间,T4为第一接收时间。
本发明实施例中,SNTP客户端获取自身的本地时钟,并将本地时钟加上时间差值,即可与SNTP服务器保持时间同步。
可以理解的是,当硬件电路检测到向服务器发送的时间同步请求报文时,硬件电路获取第一发送时间;当硬件电路检测到服务器发送的时间同步响应报文时,直接获取第一接收时间,使得客户端获取到的第一发送时间更接近真正的时间同步请求报文的发出时间、第一接收时间更接近真正的时间同步响应报文的接收时间,故,客户端利用第一发送时间和第一接收时间计算时间差值时,能够降低计算误差,进而提高客户端的对时精度。
实施例二
本发明实施例提供一种本发明实施例提供一种时间同步方法,应用于客户端,客户端上设置硬件电路,客户端通过硬件电路与服务器进行数据交互,如图6所示,该方法可以包括:
S201、客户端利用客户端程序得到时间同步请求报文。
本发明实施例提供的一种时间同步方法适用于将客户端的时间同步为与服务器时间一致的场景下。
本发明实施例中,客户端为SNTP客户端、与客户端进行数据交互的服务器为SNTP服务器。
本发明实施例中,硬件电路为FPGA等,具体的根据实际情况进行选择,本发明实施例不做具体的限定。
本发明实施例中,SNTP客户端的CPU运行客户端程序,得到SNTP对时请求报文,其中,CPU上设置有MAC接口,FPGA上设置有与CPU配对的MAC接口,CPU和FPGA通过MAC接口进行MAC直连。
S202、客户端将时间同步请求报文封装成第一报文帧。
当客户端利用客户端程序得到时间同步请求报文之后,客户端就要将时间同步请求报文封装成第一报文帧了。
本发明实施例中,硬件电路上还设置有以太网接口,SNTP服务器上也设置有以太网接口,硬件电路和SNTP服务器通过以太网接口连接,并进行数据交互。
本发明实施例中,SNTP客户端和SNTP服务器之间传输的是数据帧,故,SNTP客户端和SNTP服务器在发送SNTP对时报文时,是以以太网报文帧的格式进行发送的。
本发明实施例中,SNTP客户端将SNTP对时请求报文封装成第一报文帧。
S203、客户端通过硬件电路将第一报文帧发送至服务器。
当客户端将时间同步请求报文封装成第一报文帧之后,客户端就要通过硬件电路将第一报文帧发送至服务器了。
本发明实施例中,第一报文帧的发送顺序为以太网前导码、以太网帧开始分界符和以太网报文,FPGA通过以太网接口按照第一报文帧的发送顺序将第一报文帧发送至服务器。
S204、在通过硬件电路检测到第一报文帧中的第一帧起始符时,客户端利用硬件电路获取第一发送时间。
当客户端通过硬件电路将第一报文帧发送至服务器之后,客户端就要利用硬件电路检测第一报文帧中的第一帧起始符了,并在检测到第一帧起始符时,通过硬件电路获取第一发送时间。
本发明实施例中,FPGA在检测到传输以太网帧开始分界符时,获取第一发送时间。
S205、客户端在第一报文帧添加第一发送时间,以完成将时间同步请求报文发送至服务器的过程。
当客户端获取到第一发送时间时,客户端就要在第一报文帧添加第一发送时间,来完成将时间同步请求报文发送至服务其的过程了。
本发明实施例中,SNTP客户端将第一发送时间填入SNTP对时请求报文的Originate Timestamp字段中。
示例性的,如图4所示,SNTP客户端发送SNTP对时请求报文帧的发送顺序为以太网前导码、以太网帧开始分界符和以太网报文,FPGA在检测到传输以太网帧开始分界符时,获取系统时间,并将该系统时间填入SNTP对时请求报文的Originate Timestamp字段中。
本发明实施例中,FPGA继续将添加了第一接收时间的第一报文帧发送至SNTP服务器中,以完成将时间同步请求报文发送至SNTP服务器的过程。
S206、服务器获取接收到第一报文帧的第二接收时间,并将第二接收时间添加至第一报文帧中。
当客户端将第一报文帧发送至服务器之后,服务器就要获取接收到第一报文帧的第二接收时间,并将第二接收时间添加至第一报文帧中了。
本发明实施例中,SNTP服务器在接收到第一报文帧时,获取第二接收时间,并将第二接收时间添加至SNTP对时请求报文的Receive Timestamp字段中。
S207、当服务器响应第一报文帧时,服务器获取第二发送时间,并将第二发送时间添加至第一报文帧中,得到第二报文帧。
当服务器将第二接收时间添加至第一报文帧之后,服务器就要响应第一报文帧了,此时服务器获取第二发送时间,并将第二发送时间添加至第一报文帧中,得到第二报文帧。
本发明实施例中,SNTP服务器响应第一报文帧,此时,SNTP服务器获取响应第一报文帧的第二发送时间,并将第二发送时间添加至第一报文帧中,得到第二报文帧。
本发明实施例中,SNTP服务器获取本地时钟信息,填入SNTP对时请求报文的Transmit Timestamp字段中。
S208、服务器将第二报文帧发送至客户端。
当服务器得到第二报文帧之后,服务器就要将第二报文帧发送至客户端了。
本发明实施例中,SNTP服务器通过以太网接口将第二报文帧发送至FPGA。
S209、在通过硬件电路检测到第二报文帧的第二起始符时,客户端获取第一接收时间。
当客户端接收到第二报文帧之后,客户端就要通过硬件电路检测第二报文帧的第二起始符,并在检测到第二起始符时,利用硬件电路获取第一接收时间了。
本发明实施例中,当FPGA接收第二报文帧之后,FPGA检测是否接收到以太网帧开始分界符,当FPGA接收到以太网帧开始分界符时,FPGA获取第一接收时间。
S210、客户端将第一接收时间添加至第二报文帧中。
当客户端获取到第一接收时间之后,客户端就要将第一接收时间添加至第二报文帧中了。
本发明实施例中,SNTP客户端将第一接收时间填入SNTP对时响应报文的Destination Timestamp中。
示例性的,如图5所示,SNTP客户端接收到SNTP对时响应报文帧的接收顺序为以太网前导码、以太网帧开始分界符和以太网报文,FPGA在接收到以太网帧开始分界符时,获取系统时间,并将该系统时间填入SNTP对时响应报文的Destination Timestamp字段中。
S211、客户端将第二报文帧解封成时间同步同步响应报文。
当客户端将第一接收时间添加至第二报文帧之后,客户端就要将第二报文帧解封成时间同步响应报文了。
本发明实施例中,SNTP客户端将第二报文帧解封成时间同步响应报文。
S212、客户端从时间同步响应报文中获取第一发送时间、第一接收时间、第二发送时间和第二接收时间。
当客户端将第二报文帧解封成时间同步响应报文之后,客户端就要从时间同步响应报文获取第一发送时间、第一接收时间、第二发送时间和第二接收时间了。
本发明实施例中,预设同步算法为:
((T2-T1)+(T3-T4))/2(1)
其中,T1为第一发送时间,T2为第二接收时间,T3为第二发送时间,T4为第一接收时间。
本发明实施例中,SNTP客户端从时间同步响应报文的Originate Timestamp字段中获取T1、Receive Timestamp字段中获取T2、Transmit Timestamp字段中获取T3和Destination Timestamp字段中获取T4。
S213、客户端获取第二接收时间和第一发送时间的第一时间差和第一接收时间和第二发送时间的第二时间差。
当客户端获取到第一发送时间、第一接收时间、第二发送时间和第二接收时间之后,客户端就要获取第二接收时间和第一发送时间的第一时间差、和第一接收时间和第二发送时间的第二时间差了。
本发明实施例中,第一时间差为T2-T1,第二时间差为T3-T4。
S214、客户端计算第一时间差和第二时间差的平均值。
当客户端获取到第一时间差和第二时间差之后,客户端就要计算第一时间差和第二时间差的平均值了。
本发明实施例中,SNTP计算(T2-T1)+(T3-T4)/2,得到第一时间差和第二时间差的平均值。
S215、客户端将平均值确定为时间差值,以利用时间差值完成客户端和服务器之间的时间同步的过程。
当客户端计算出第一时间差和第二时间差的平均值之后,客户端就要将平均值确定为时间差值,并利用时间差值完成客户端和服务器之间的时间同步的过程了。
本发明实施例中,SNTP客户端获取自身的本地时钟,并将本地时钟加上时间差值,即可与SNTP服务器保持时间同步。
示例性的,如图7所示,在SNTP客户端向SNTP服务器发送同步请求时,记录第一发送时间T1;在SNTP服务器接收到SNTP客户端发送的同步请求时,记录第二接收时间T2;在SNTP服务器响应同步请求时,记录第二发送时间T3;在SNTP客户端接收到服务器发送的响应同步请求时,记录第一接收时间T4。
可以理解的是,当硬件电路检测到向服务器发送的时间同步请求报文时,硬件电路获取第一发送时间;当硬件电路检测到服务器发送的时间同步响应报文时,直接获取第一接收时间,使得客户端获取到的第一发送时间更接近真正的时间同步请求报文的发出时间、第一接收时间更接近真正的时间同步响应报文的接收时间,故,客户端利用第一发送时间和第一接收时间计算时间差值时,能够降低计算误差,进而提高客户端的对时精度。
实施例三
本发明实施例提供一种客户端1,所述客户端1与服务器2进行数据交互,如图8所示,该客户端1包括:
处理器10,所述处理器设置有第一通信接口100;
与所述处理器10通过所述第一通信接口100和第二通信接口110连接的硬件电路11,所述硬件电路11上设置有所述第二通信接口110和第三通信接口111,所述硬件电路11通过所述第三通信接口111与所述服务器2连接并进行数据交互;其中,
所述处理器10,用于当运行客户端程序得到时间同步请求报文时,将所述时间同步请求报文传输至所述硬件电路11;
所述硬件电路11,用于当将所述时间同步请求报文发送至所述服务器2时,获取第一发送时间;当从所述服务器2获取到响应所述时间同步请求报文的时间同步响应报文时,获取第一接收时间,并将所述第一发送时间和所述第一接收时间传输至所述处理器10;
所述处理器10,还用于利用所述第一发送时间、所述第一接收时间和预设同步算法,计算出所述客户端与所述服务器之间的时间差值;以利用所述时间差值完成所述客户端和所述服务器之间的时间同步的过程。
可选的,所述硬件电路11,具体用于将所述第一发送时间添加至所述时间同步请求报文中,并将所述时间同步请求报文发送至所述服务器2;
所述硬件电路11,具体用于将所述第一接收时间添加至所述时间同步响应报文,并将所述时间同步响应报文传输至所述处理器10,以将所述第一发送时间和所述第一接收时间传输至所述处理器10。
可选的,所述时间同步响应报文包括第二接收时间和第二发送时间,所述第二接收时间为所述服务器2接收到所述时间同步请求报文的时间;所述第二发送时间为所述服务器2发送所述时间同步请求报文的时间;
所述处理器10,具体用于利用所述第一发送时间、所述第一接收时间、所述第二发送时间、所述第二接收时间和所述预设同步算法,得到时间差值。
可选的,所述处理器10,具体用于分别获取所述第二接收时间和所述第一发送时间的第一时间差、所述第一接收时间和所述第二发送时间的第二时间差;计算出所述第一时间差和所述第二时间差的平均值,将所述平均值确定为所述时间差值。
可选的,所述硬件电路11,还用于将所述时间同步请求报文封装成第一报文帧,将所述第一报文帧发送至所述服务器2;从所述服务器2接收第二报文帧,并将所述第二报文帧解封成所述时间同步响应报文。
可选的,所述硬件电路11,具体用于当检测到所述第一报文帧的第一帧起始符时,获取所述第一发送时间;在所述第一报文帧添加所述第一发送时间;将所述第一报文帧发送至所述服务器;
所述硬件电路11,具体用于当检测到所述第二报文帧的第二帧起始符时,获取所述第一接收时间;将所述第一接收时间添加至所述第二报文帧中;
所述处理器10,还用于将所述第二报文帧解封成所述时间同步响应报文、从所述时间同步响应报文中获取所述第一发送时间、所述第一接收时间、所述第二发送时间和所述第二接收时间。
示例性的,如图9所示,SNTP客户端内设置有CPU和FPGA,其中CPU上设置有MAC接口,FPGA上设置有MAC接口和以太网接口,CPU和FPGA通过MAC接口进行MAC直连,SNTP服务器上设置有以太网接口,SNTP客户端通过FPGA上的以太网接口和SNTP服务器进行连接,并进行SNTP对时报文的传输过程。
在实际应用中,上述处理器10可以为特定用途集成电路(ASIC,ApplicationSpecific Integrated Circuit)、数字信号处理器(DSP,Digital Signal Processor)、数字信号处理装置(DSPD,Digital Signal Processing Device)、可编程逻辑装置(PLD,Programmable Logic Device)、现场可编程门阵列(FPGA,Field Programmable GateArray)、中央处理器(处理器,Central Processing Unit)、控制器、微控制器、微处理器中的至少一种。可以理解地,对于不同的设备,用于实现上述第一处理器功能的电子器件还可以为其它,本发明实施例不作具体限定,该客户端1还包括存储器12,其中,存储器12用于存储可执行程序代码,该程序代码包括计算机操作指令,存储器12可能包含高速RAM存储器,也可能还包括非易失性存储器,例如,至少一个磁盘存储器。
在实际应用中,上述存储器12可以是易失性第一存储器(volatile memory),例如随机存取第二存储器(RAM,Random-Access Memory);或者非易失性第二存储器(non-volatile memory),例如只读第二存储器(ROM,Read-Only Memory),快闪第二存储器(flash memory),硬盘(HDD,Hard Disk Drive)或固态硬盘(SSD,Solid-State Drive);或者上述种类的第二存储器的组合,并向处理器10提供指令和数据。
另外,在本实施例中的各功能模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能模块的形式实现。
所述集成的单元如果以软件功能模块的形式实现并非作为独立的产品进行销售或使用时,可以存储在一个计算机可读取存储介质中,基于这样的理解,本实施例的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)或processor(处理器)执行本实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、ROM、RAM、磁碟或者光盘等各种可以存储程序代码的介质。
本发明实施例提供一种计算机可读存储介质,其上存储有计算机程序,应用于客户端1中,该计算机程序被执行时实现如实施例一和实施例二所述的方法。
具体来讲,本实施例中的一种时间同步方法对应的程序指令可以被存储在光盘,硬盘,U盘等存储介质上,当存储介质中的与一种时间同步方法对应的计算机程序指令被一电子设备读取或被执行时,包括如下步骤:
利用客户端程序得到时间同步请求报文;
当通过所述硬件电路将所述时间同步请求报文发送至所述服务器时,利用所述硬件电路获取第一发送时间;
将所述第一发送时间添加至所述时间同步请求报文,以完成将所述时间同步请求报文发送至所述服务器的过程;
当通过所述硬件电路从所述服务器接收到时间同步响应报文时,利用所述硬件电路获取第一接收时间,所述时间同步响应报文为响应所述时间同步请求报文的报文;
根据所述第一发送时间、第一接收时间和预设同步算法,计算出所述客户端与所述服务器之间的时间差值,以利用所述时间差值完成所述客户端和所述服务器之间的时间同步的过程。
本领域内的技术人员应明白,本发明的实施例可提供为方法、系统、或计算机程序产品。因此,本发明可采用硬件实施例、软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器和光学存储器等)上实施的计算机程序产品的形式。
本发明是参照根据本发明实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
以上所述,仅为本发明较佳实施例而已,并非用于限定本发明的保护范围。
Claims (13)
1.一种时间同步方法,应用于客户端,所述客户端上设置硬件电路,所述客户端通过所述硬件电路与服务器进行数据交互,其特征在于,所述方法包括:
利用客户端程序得到时间同步请求报文;
当通过所述硬件电路将所述时间同步请求报文发送至所述服务器时,利用所述硬件电路获取第一发送时间;
将所述第一发送时间添加至所述时间同步请求报文,以完成将所述时间同步请求报文发送至所述服务器的过程;
当通过所述硬件电路从所述服务器接收到时间同步响应报文时,利用所述硬件电路获取第一接收时间,所述时间同步响应报文为响应所述时间同步请求报文的报文;
根据所述第一发送时间、第一接收时间和预设同步算法,计算出所述客户端与所述服务器之间的时间差值,以利用所述时间差值完成所述客户端和所述服务器之间的时间同步的过程。
2.根据权利要求1所述的方法,其特征在于,所述时间同步响应报文包括第二接收时间和第二发送时间,所述第二接收时间为所述服务器接收到所述时间同步请求报文的时间,所述第二发送时间为所述服务器发送所述时间同步响应报文的时间,所述根据所述第一发送时间、第一接收时间和预设同步算法,计算出所述客户端与所述服务器之间的时间差值,包括:
利用所述第一发送时间、所述第一接收时间、所述第二发送时间、所述第二接收时间和所述预设同步算法,计算出所述时间差值。
3.根据权利要求2所述的方法,其特征在于,所述利用所述第一发送时间、所述第一接收时间、所述第二发送时间、所述第二接收时间和所述预设同步算法,计算出所述时间差值,包括:
分别获取所述第二接收时间和所述第一发送时间的第一时间差、所述第一接收时间和所述第二发送时间的第二时间差;
计算出所述第一时间差和所述第二时间差的平均值;
将所述平均值确定为所述时间差值。
4.根据权利要求1所述的方法,其特征在于,所述当通过所述硬件电路将所述时间同步请求报文发送至所述服务器时,利用所述硬件电路获取第一发送时间,包括:
将所述时间同步请求报文封装成第一报文帧;
通过所述硬件电路将所述第一报文帧发送至所述服务器;
当通过所述硬件电路检测到所述第一报文帧中的第一帧起始符时,获取所述第一发送时间;
相应的,所述将所述第一发送时间添加至所述时间同步请求报文,包括:
在所述第一报文帧添加所述第一发送时间。
5.根据权利要求1所述的方法,其特征在于,所述利用所述硬件电路获取第一接收时间,包括:
从所述服务器接收第二报文帧;
在通过所述硬件电路检测到所述第二报文帧的第二起始符时,获取所述第一接收时间。
6.根据权利要求2或5所述的方法,其特征在于,所述利用所述硬件电路获取第一接收时间之后,所述根据所述第一发送时间、第一接收时间和预设同步算法,计算出所述客户端与所述服务器之间的时间差值之前,所述方法还包括:
将所述第一接收时间添加至所述第二报文帧中;
将所述第二报文帧解封成所述时间同步响应报文;
从所述时间同步响应报文中获取所述第一发送时间、所述第一接收时间、所述第二发送时间和所述第二接收时间。
7.一种客户端,所述客户端与服务器进行数据交互,其特征在于,所述客户端包括:
处理器,所述处理器设置有第一通信接口;
与所述处理器通过所述第一通信接口和第二通信接口连接的硬件电路,所述硬件电路上设置有所述第二通信接口和第三通信接口,所述硬件电路通过所述第三通信接口与所述服务器连接;其中,
所述处理器,用于当运行客户端程序得到时间同步请求报文时,将所述时间同步请求报文传输至所述硬件电路;
所述硬件电路,用于当将所述时间同步请求报文发送至所述服务器时,获取第一发送时间;当从所述服务器接收到响应所述时间同步请求报文的时间同步响应报文时,获取第一接收时间,并将所述第一发送时间和所述第一接收时间传输至所述处理器;
所述处理器,还用于利用所述第一发送时间、所述第一接收时间和预设同步算法,计算出所述客户端与所述服务器之间的时间差值;以利用所述时间差值完成所述客户端和所述服务器之间的时间同步的过程。
8.根据权利要求7所述的客户端,其特征在于,
所述硬件电路,具体用于将所述第一发送时间添加至所述时间同步请求报文中,并将所述时间同步请求报文发送至所述服务器;
所述硬件电路,具体用于将所述第一接收时间添加至所述时间同步响应报文,并将所述时间同步响应报文传输至所述处理器,以将所述第一发送时间和所述第一接收时间传输至所述处理器。
9.根据权利要求7所述的客户端,其特征在于,所述时间同步响应报文包括第二接收时间和第二发送时间,所述第二接收时间为所述服务器接收到所述时间同步请求报文的时间,所述第二发送时间为所述服务器发送所述时间同步请求报文的时间;
所述处理器,具体用于利用所述第一发送时间、所述第一接收时间、所述第二发送时间、所述第二接收时间和所述预设同步算法,得到时间差值。
10.根据权利要求9所述的客户端,其特征在于,
所述处理器,具体用于分别获取所述第二接收时间和所述第一发送时间的第一时间差、所述第一接收时间和所述第二发送时间的第二时间差;计算出所述第一时间差和所述第二时间差的平均值,将所述平均值确定为所述时间差值。
11.根据权利要求8所述的客户端,其特征在于,
所述硬件电路,还用于将所述时间同步请求报文封装成第一报文帧,将所述第一报文帧发送至所述服务器;从所述服务器接收第二报文帧,并将所述第二报文帧解封成所述时间同步响应报文。
12.根据权利要求9或11所述的客户端,其特征在于,
所述硬件电路,具体用于当检测到所述第一报文帧的第一帧起始符时,获取所述第一发送时间;在所述第一报文帧添加所述第一发送时间;将所述第一报文帧发送至所述服务器;
所述硬件电路,具体用于当检测到所述第二报文帧的第二帧起始符时,获取所述第一接收时间;将所述第一接收时间添加至所述第二报文帧中;
所述处理器,还用于将所述第二报文帧解封成所述时间同步响应报文;从所述时间同步响应报文中获取所述第一发送时间、所述第一接收时间、所述第二发送时间和所述第二接收时间。
13.一种计算机可读存储介质,其上存储有计算机程序,应用于客户端中,其特征在于,该计算机程序被的处理器执行时实现如权利要求1-6任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810543013.1A CN108737006A (zh) | 2018-05-30 | 2018-05-30 | 一种时间同步方法、客户端及计算机可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810543013.1A CN108737006A (zh) | 2018-05-30 | 2018-05-30 | 一种时间同步方法、客户端及计算机可读存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN108737006A true CN108737006A (zh) | 2018-11-02 |
Family
ID=63936896
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810543013.1A Pending CN108737006A (zh) | 2018-05-30 | 2018-05-30 | 一种时间同步方法、客户端及计算机可读存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN108737006A (zh) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109603153A (zh) * | 2018-12-13 | 2019-04-12 | 网易(杭州)网络有限公司 | 虚拟事件处理方法及装置、电子设备和存储介质 |
CN109981206A (zh) * | 2019-02-26 | 2019-07-05 | 深圳猛犸电动科技有限公司 | 对时方法、装置、系统及终端设备、存储介质 |
CN112486249A (zh) * | 2020-11-30 | 2021-03-12 | 掌阅科技股份有限公司 | 时间同步方法、计算设备及计算机存储介质 |
CN114143219A (zh) * | 2021-12-01 | 2022-03-04 | 北京联创新天科技有限公司 | 一种b/s系统架构的网络监控方法、装置、介质及设备 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102130735A (zh) * | 2010-11-09 | 2011-07-20 | 华为技术有限公司 | 一种传送设备及其实现时钟和时间同步的方法 |
US20160043865A1 (en) * | 2014-08-06 | 2016-02-11 | The Government Of The United States Of America, As Represented By The Secretary Of The Navy | System and method for authenticating a network time protocol (ntp) |
CN105680975A (zh) * | 2016-03-07 | 2016-06-15 | 浙江大学 | 一种主从结构多节点网络的时间同步方法 |
CN106230540A (zh) * | 2016-06-30 | 2016-12-14 | 电信科学技术第五研究所 | 高精度ntp报文接收方法和发送方法 |
-
2018
- 2018-05-30 CN CN201810543013.1A patent/CN108737006A/zh active Pending
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102130735A (zh) * | 2010-11-09 | 2011-07-20 | 华为技术有限公司 | 一种传送设备及其实现时钟和时间同步的方法 |
US20160043865A1 (en) * | 2014-08-06 | 2016-02-11 | The Government Of The United States Of America, As Represented By The Secretary Of The Navy | System and method for authenticating a network time protocol (ntp) |
CN105680975A (zh) * | 2016-03-07 | 2016-06-15 | 浙江大学 | 一种主从结构多节点网络的时间同步方法 |
CN106230540A (zh) * | 2016-06-30 | 2016-12-14 | 电信科学技术第五研究所 | 高精度ntp报文接收方法和发送方法 |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109603153A (zh) * | 2018-12-13 | 2019-04-12 | 网易(杭州)网络有限公司 | 虚拟事件处理方法及装置、电子设备和存储介质 |
CN109603153B (zh) * | 2018-12-13 | 2022-07-12 | 网易(杭州)网络有限公司 | 虚拟事件处理方法及装置、电子设备和存储介质 |
CN109981206A (zh) * | 2019-02-26 | 2019-07-05 | 深圳猛犸电动科技有限公司 | 对时方法、装置、系统及终端设备、存储介质 |
CN109981206B (zh) * | 2019-02-26 | 2021-01-26 | 深圳猛犸电动科技有限公司 | 对时方法、装置、系统及终端设备、存储介质 |
CN112486249A (zh) * | 2020-11-30 | 2021-03-12 | 掌阅科技股份有限公司 | 时间同步方法、计算设备及计算机存储介质 |
CN112486249B (zh) * | 2020-11-30 | 2021-09-03 | 掌阅科技股份有限公司 | 时间同步方法、计算设备及计算机存储介质 |
CN114143219A (zh) * | 2021-12-01 | 2022-03-04 | 北京联创新天科技有限公司 | 一种b/s系统架构的网络监控方法、装置、介质及设备 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108737006A (zh) | 一种时间同步方法、客户端及计算机可读存储介质 | |
CN103929293B (zh) | 非对称延迟的时间同步方法及系统 | |
CN103109501A (zh) | 网络时延测量方法、装置和系统 | |
CN111162971B (zh) | 一种时延确定方法及装置 | |
CN110099439B (zh) | 时间同步方法和装置 | |
CN103188064A (zh) | 时钟同步方法及装置 | |
CN109257133B (zh) | 一种应用于lte轨道交通网的全网时钟同步方法及装置 | |
CN103138887A (zh) | 一种1588事件报文的处理方法及系统 | |
CN111327385A (zh) | 物联网设备的时钟同步方法、装置及设备 | |
WO2015109819A1 (zh) | 光突发传送网节点时隙同步的训练方法、节点设备和网络 | |
CN110932931A (zh) | 用于数据中心网络延迟的检测方法及装置 | |
WO2017096994A1 (zh) | 一种时钟同步的方法、设备和系统、存储介质 | |
WO2012003731A1 (zh) | 通讯录同步方法和系统 | |
WO2010091624A1 (zh) | 流程跟踪方法以及装置和系统 | |
CN105591892B (zh) | 一种平滑重启流程的启动方法和装置 | |
WO2014075260A1 (zh) | 一种时延补偿方法及装置 | |
CN102404152B (zh) | 识别应答报文的方法及设备 | |
WO2021233313A1 (zh) | 配置端口状态的方法、装置、系统及存储介质 | |
CN116723195B (zh) | 数据传输方法、装置、电子设备及存储介质 | |
WO2010102565A1 (zh) | 时间同步的方法、装置和系统 | |
US20080212564A1 (en) | Clock Synchronization Method For Wireless 1394 Heterogeneous Networks | |
CN112039621B (zh) | 一种时间同步方法和系统 | |
CN112381599A (zh) | 一种基于区块链技术的共享充电宝租赁系统及方法 | |
CN109274763B (zh) | 一种信息同步方法及双机热备设备 | |
CN114389733B (zh) | Ptp主时钟设备、时钟同步方法及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20181102 |