CN103078697A - 一种分布式时钟同步方法 - Google Patents
一种分布式时钟同步方法 Download PDFInfo
- Publication number
- CN103078697A CN103078697A CN2012105349359A CN201210534935A CN103078697A CN 103078697 A CN103078697 A CN 103078697A CN 2012105349359 A CN2012105349359 A CN 2012105349359A CN 201210534935 A CN201210534935 A CN 201210534935A CN 103078697 A CN103078697 A CN 103078697A
- Authority
- CN
- China
- Prior art keywords
- clock
- terminal
- computer
- distributed
- adjacent end
- 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.)
- Granted
Links
Images
Landscapes
- Synchronisation In Digital Transmission Systems (AREA)
- Hardware Redundancy (AREA)
Abstract
本发明公开了一种分布式时钟同步方法,具体为:初始化网络连接,各终端搜索其相邻终端,并确定本机时钟;各终端周期性广播本机时钟,同时接收相邻终端的时钟;各终端依据本机时钟和相邻终端时钟计算本机时钟差异数值;若时钟差异数值大于等于精度阈值,则终端的时钟更新为本机当前时钟与时钟差异数值之和,否则,终端的时钟保持不变。本发明不需依赖一台标准时钟计算机完成时钟同步,不会因为标准时钟失效或与标准时钟的通信失效而导致时钟同步系统崩溃,无需人工配置便可实现对新增计算机的时钟同步,增强了系统运行的稳定性和扩展性。
Description
技术领域
本发明涉及时钟同步技术领域,具体涉及一种分布式法时钟同步方法,适用于多台计算机并行合作计算过程中的时钟同步过程。
背景技术
目前,时钟同步技术用于各种应用中。在计算机并行计算领域(如余度控制、云计算、数据中心等),时钟同步重要的技术环节。时钟同步也叫“对钟”。要把分布在各地的时钟对准(同步起来),最直观的方法就是“搬钟”,一般使用一个标准钟作搬钟,使各地的钟均与标准钟对准。或者使搬钟首先与系统的标准时钟对准,然后使系统中的其他时针与搬钟比对,实现系统其他时钟与系统统一标准时钟同步。
现有计算机时钟同步技术中,有两点待改进的技术问题:一、需要依赖于和标准钟(主时钟计算机)对比。如果任何因素导致和标准计算机通信失效,则系统内所有计算机的时钟同步均会失效;二、系统中新增或减去一台需要时钟同步的计算机,系统无法做到自动配置,必须进行人工设置才能实现。
发明内容
本发明的目的在于提供一种分布式时钟同步方法,不需依赖一台标准时钟计算机完成时钟同步,不会因为标准时钟失效或与标准时钟的通信失效而导致时钟同步系统崩溃,无需人工配置便可实现对新增计算机的时钟同步,增强了系统运行的稳定性和扩展性。
一种分布式时钟同步方法,具体为:
初始化网络连接,各终端搜索其相邻终端,并确定本机时钟;
各终端周期性广播本机时钟,同时接收相邻终端的时钟;
各终端i计算本机时钟差异数值 xi(k)为kT时刻终端i的时钟,Ni(k)为kT时刻终端i的相邻终端集合,ni(k)为kT时刻终端i的相邻终端总数,T为时钟调整周期,k为自然数;
若时钟差异数值xi(k+1)大于等于精度阈值,则终端i的时钟更新为本机当前时钟与时钟差异数值xi(k+1)之和,否则,终端i的时钟保持不变。
本发明的有益效果是:本发明不需依赖一台标准时钟计算机完成时钟同步,不会因为标准时钟失效或与标准时钟的通信失效而导致时钟同步系统崩溃,增强了系统运行的稳定性。并且系统中可随时增加新的计算机单元,无需人工配置便可实现对新增计算机的时钟同步。分布式计算方法更适合与计算机集群的并行协调运算系统(如余度控制、云计算、数据中心等)。
附图说明
下面结合附图和实施例对本发明进一步说明。
图1是运行在系统中的程序流程框图。
图2是通过仿真获得的系统中各计算机终端时钟同步过程的时差状态变化示例图。
具体实施方式
下面结合附图对本发明做进一步的详细描述。
本发明解决系统同步问题的基本方案是:通过网络互联方式将系统内所有的计算机联网,各计算机都能和网内的其他计算机进行通信。软件实现一套通信和算法控制程序应用在所有计算机内。程序运行后,各计算机周期性的同网内其他计算机进行通信,广播本计算机的时钟状态,并获取其他计算机的时钟状态;程序再将所有获取的时钟状态输入分布式算法中计算得到自身需要调整的时钟差值;程序最后判断差值是否在可忍受的时钟误差之内,如果是则不进行调整,如果否则按照差值调整本计算机时钟。此负反馈过程周期性的运行,运行周期由所需控制的时钟同步精度确定。
本发明中,通信网络由路由器、交换机等任何网络连接方案实现。微型机、工作站、服务器、笔记本、小型机等任何计算机终端都可以应用于时钟同步系统。
如图1所示,本发明具体包括以下步骤:
(1)同步前准备动作:首先需要初始化系统网络连接,各终端首先配置自身网络地址,而后开始遍历搜寻网络中存在的相邻终端,获得响应后,建立网络连接。系统网络建立后,开始通讯延迟校正,各终端向系统中相邻终端发送命令,获得返回信息后计算通讯延迟时间,记录与其他所有终端的延迟时间为校正因子,用于同步过程中的时钟补偿。获得通信延迟校正因子后,各终端获得自身当前时钟状态,启动循环同步过程。
(2)本机周期性广播自身时钟状态,同时多线程接收相邻终端时钟状态。
(3)根据自身时钟状态及接收到的相邻终端时钟状态,运用分布式算法,计算得到自身需要调节的时钟差异数值。
(4)根据系统定义的时钟同步精度情况,判断上一步骤得到的调节差异数值是否需要应用。当调节值大于精度阈值时,启动调整;当调节值小于精度要求时,终端不做调整。精度阈值的取值范围可以根据系统的要求调节,一般而言在1ms以内。
(5)终端根据时钟差异数值的正负情况,选择调快或调慢时钟,在当前时钟状态的基础上叠加时钟差异数值,设定为新的时钟状态。
模型给出了一种适用于网络时钟同步的分布式算法,分布式算法描述式为: xi(k)为kT时刻终端i的时钟,Ni(k)为kT时刻终端i的相邻终端集合,ni(k)为kT时刻终端i的相邻终端总数,T为时钟调整周期,k为自然数;
根据此分布式模型,终端将自身时钟状态xi(k)和通过网络获得的临近终端时钟状态xj(k)代入公式计算,输出本机时钟差异数值xi(k+1)。
当网络是连通时,采用该分布式算法系统能实现所有接入终端的时钟同步。
图2是通过仿真获得的系统中各计算机终端时钟同步过程的时差状态变化示例图。其中假设网络中存在6个终端X0~X5,X0为初始时钟最慢的终端,X1~X5初始和X0的时钟差异分别为3ms、12ms、4ms、8.5ms、0.8ms。经过约15ms的同步过程后,网络中的6台终端达到时钟同步。
Claims (1)
1.一种分布式时钟同步方法,具体为:
初始化网络连接,各终端搜索其相邻终端,并确定本机时钟;
各终端周期性广播本机时钟,同时接收相邻终端的时钟;
各终端i计算本机时钟差异数值 xi(k)为kT时刻终端i的时钟,Ni(k)为kT时刻终端i的相邻终端集合,ni(k)为kT时刻终端i的相邻终端总数,T为时钟调整周期,k为自然数;
若时钟差异数值xi(k+1)大于等于精度阈值,则终端i的时钟更新为本机当前时钟与时钟差异数值xi(k+1)之和,否则,终端i的时钟保持不变。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201210534935.9A CN103078697B (zh) | 2012-12-11 | 2012-12-11 | 一种分布式时钟同步方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201210534935.9A CN103078697B (zh) | 2012-12-11 | 2012-12-11 | 一种分布式时钟同步方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN103078697A true CN103078697A (zh) | 2013-05-01 |
CN103078697B CN103078697B (zh) | 2015-09-09 |
Family
ID=48155112
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201210534935.9A Expired - Fee Related CN103078697B (zh) | 2012-12-11 | 2012-12-11 | 一种分布式时钟同步方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN103078697B (zh) |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105490799A (zh) * | 2016-01-15 | 2016-04-13 | 南京邮电大学 | 一种基于双向报文交换的多终端时间同步方法 |
CN105763279A (zh) * | 2016-02-24 | 2016-07-13 | 华东交通大学 | 网络系统分布节点时钟中的最优主时钟确定方法 |
CN106301953A (zh) * | 2016-09-20 | 2017-01-04 | 中国科学院计算技术研究所 | 适用于时间触发以太网的分布式容错时钟同步方法及系统 |
CN106411601A (zh) * | 2016-10-26 | 2017-02-15 | 上海斐讯数据通信技术有限公司 | 一种批量配置云终端时间的系统及方法 |
CN109150358A (zh) * | 2018-08-16 | 2019-01-04 | 中国科学院声学研究所 | 一种分布式时钟同步方法及系统 |
CN109412695A (zh) * | 2018-12-28 | 2019-03-01 | 中国船舶重工集团公司第七〇九研究所 | 一种基于星形拓扑结构的光纤can2.0b总线路由系统 |
CN114139039A (zh) * | 2021-11-30 | 2022-03-04 | 百度在线网络技术(北京)有限公司 | 服务稳定性确定方法、装置、设备以及存储介质 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2004066530A1 (en) * | 2003-01-14 | 2004-08-05 | Honeywell International Inc. | Method and apparatus for the synchronization of a system time of a communications network with a clock reference |
CN101982959A (zh) * | 2010-11-24 | 2011-03-02 | 电子科技大学 | 网络的按需时间同步方法 |
CN102098194A (zh) * | 2009-12-10 | 2011-06-15 | 中兴通讯股份有限公司 | 一种在局域网络中实现时间同步的方法及系统 |
-
2012
- 2012-12-11 CN CN201210534935.9A patent/CN103078697B/zh not_active Expired - Fee Related
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2004066530A1 (en) * | 2003-01-14 | 2004-08-05 | Honeywell International Inc. | Method and apparatus for the synchronization of a system time of a communications network with a clock reference |
CN102098194A (zh) * | 2009-12-10 | 2011-06-15 | 中兴通讯股份有限公司 | 一种在局域网络中实现时间同步的方法及系统 |
CN101982959A (zh) * | 2010-11-24 | 2011-03-02 | 电子科技大学 | 网络的按需时间同步方法 |
Cited By (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105490799A (zh) * | 2016-01-15 | 2016-04-13 | 南京邮电大学 | 一种基于双向报文交换的多终端时间同步方法 |
CN105490799B (zh) * | 2016-01-15 | 2018-04-03 | 南京邮电大学 | 一种基于双向报文交换的多终端时间同步方法 |
CN105763279A (zh) * | 2016-02-24 | 2016-07-13 | 华东交通大学 | 网络系统分布节点时钟中的最优主时钟确定方法 |
CN106301953A (zh) * | 2016-09-20 | 2017-01-04 | 中国科学院计算技术研究所 | 适用于时间触发以太网的分布式容错时钟同步方法及系统 |
CN106301953B (zh) * | 2016-09-20 | 2019-05-14 | 中国科学院计算技术研究所 | 适用于时间触发以太网的分布式容错时钟同步方法及系统 |
CN106411601A (zh) * | 2016-10-26 | 2017-02-15 | 上海斐讯数据通信技术有限公司 | 一种批量配置云终端时间的系统及方法 |
CN109150358A (zh) * | 2018-08-16 | 2019-01-04 | 中国科学院声学研究所 | 一种分布式时钟同步方法及系统 |
CN109412695A (zh) * | 2018-12-28 | 2019-03-01 | 中国船舶重工集团公司第七〇九研究所 | 一种基于星形拓扑结构的光纤can2.0b总线路由系统 |
CN114139039A (zh) * | 2021-11-30 | 2022-03-04 | 百度在线网络技术(北京)有限公司 | 服务稳定性确定方法、装置、设备以及存储介质 |
CN114139039B (zh) * | 2021-11-30 | 2022-08-09 | 百度在线网络技术(北京)有限公司 | 服务稳定性确定方法、装置、设备以及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN103078697B (zh) | 2015-09-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN103078697A (zh) | 一种分布式时钟同步方法 | |
Eidson | Measurement, control, and communication using IEEE 1588 | |
CN103257670B (zh) | 嵌入式系统及其计时方法 | |
CN102084314B (zh) | 包括基于查找表的同步的电子定时器系统 | |
CN102291169B (zh) | 一种卫星星上高精度时间同步方法 | |
CN109283967A (zh) | 一种微控制单元mcu时钟校准方法及相关设备 | |
Fuller et al. | Communication simulations for power system applications | |
CN102509461B (zh) | 交通信号协调控制平滑过渡及偏差校正方法 | |
CN102412957A (zh) | 一种高精度同步时钟调整方法 | |
CN103116322A (zh) | 微调可调振荡器以匹配 can 总线的方法及can 总线通信控制器 | |
CN114095109A (zh) | 一种时钟同步方法、装置、设备及存储介质 | |
CN103220685B (zh) | 基于动态规划的传感器网络软件模型检验方法 | |
CN109302255A (zh) | 时间同步控制方法、装置、系统及计算机可读存储介质 | |
CN104601317A (zh) | 一种fpga的同步时钟装置及其控制方法 | |
CN105071892A (zh) | 一种无线传感网络的时间同步校准方法及系统 | |
CN104486058A (zh) | 一种ptp系统时间同步方法以及装置 | |
CN204392263U (zh) | 一种fpga的同步时钟装置 | |
Chen et al. | High-precision time synchronization chip design for industrial sensor and actuator network | |
DE102013222471B4 (de) | Erzeugung und verteilung einer synchronisierten zeitquelle | |
CN109799872A (zh) | 提高低解析度实时时钟唤醒精度的方法、装置及电子设备 | |
CN115529099A (zh) | 一种整车域控制器校时方法、装置、设备及存储介质 | |
Terraneo et al. | Jitter-compensated VHT and its application to WSN clock synchronization | |
CN107995681B (zh) | 一种无线传感网时间同步方法及装置 | |
CN114003252A (zh) | 配置文件自动更新方法、系统、终端及存储介质 | |
CN113552921A (zh) | 一种软硬件互锁的系统时间同步方法及系统及电子设备 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C14 | Grant of patent or utility model | ||
GR01 | Patent grant | ||
CF01 | Termination of patent right due to non-payment of annual fee |
Granted publication date: 20150909 Termination date: 20161211 |
|
CF01 | Termination of patent right due to non-payment of annual fee |