資料介紹
引言
隨著我國航天事業(yè)的飛速發(fā)展,將逐步構建多群、多任務、多功能相對獨立的測控計算機結構體系。由于實現(xiàn)功能的不同,系統(tǒng)的組織結構與操作系統(tǒng)也千差萬別,對時間精度的要求很不相同。整個系統(tǒng)必須在統(tǒng)一的時間尺度下進行工作,因此各節(jié)點之間時間的統(tǒng)一具有必要性;另一方面,當今世界寬帶網(wǎng)絡飛速發(fā)展,各種支持網(wǎng)絡系統(tǒng)也越來越多,各個網(wǎng)絡系統(tǒng)之間互聯(lián)也需要高精度、通用的時間同步。在這種狀況下,如何探索和研制簡便、可靠、準確和通用的網(wǎng)絡授時系統(tǒng)就成為迫切需要解決的問題。
要實現(xiàn)網(wǎng)絡設備時間同步,主要完成兩方面的工作內容:第一,通過某種授時方式獲取精確時間;第二,將精確時間同步到網(wǎng)絡中的每一臺設備,這也是網(wǎng)絡時間同步系統(tǒng)的設計難點。
本文將要介紹的是一種基于嵌入式實時操作系統(tǒng)VxWorks的NTP網(wǎng)絡授時服務器,其內核響應速度快,可以方便地支持實時處理,克服了以往開發(fā)網(wǎng)絡授時服務器的弊端。本文介紹了NTP服務器的原理、系統(tǒng)總體任務及其通信機制設計,并針對NTP協(xié)議運行在VxWorks下的一些問題進行了相應的改進,同時通過性能測試分析表明本系統(tǒng)的有效性。
1 NTP工作原理
1.1 NTP協(xié)議
NTP協(xié)議是通過網(wǎng)絡的通信來實現(xiàn)計算機時鐘的同步,而數(shù)據(jù)本身在網(wǎng)絡上的傳輸也是需要時間的。因此,要獲得準確的當前時間,就必須考慮網(wǎng)絡延遲造成的影響。實際上,可通過計算報文的來回程時間來估計網(wǎng)絡延遲。網(wǎng)絡時間同步的最主要問題是,如何獲得當前的準確時間。NTP通過一系列同步算法選擇精確時間,規(guī)避網(wǎng)絡延遲,保證網(wǎng)絡時間同步的安全性。
NTP 協(xié)議支持3種對時工作方式。
?、?主從模式(Server/Client mode):用戶向一個或幾個服務器提出服務請求,根據(jù)所交換的信息計算兩地時間偏差和網(wǎng)絡延遲,從中選擇認為最準確的時間偏差并調整本地的時鐘。
?、?廣播模式(Multicast/Broadcast mode):此種模式適用于高速的局域網(wǎng)中。局域網(wǎng)中的一個或多個服務器以固定的時間周期向某個多播地址廣播自己的時標,客戶端不計算時間偏差和網(wǎng)絡延遲,直接用接收到的時標修正自己的時鐘,忽略各種誤差。
③ 對稱模式(Symmetric mode):兩個以上的時間服務器互為主從進行時間消息的通信,相互校正對方的時間以維持整個同步子網(wǎng)的時間一致性。
根據(jù)本系統(tǒng)的特點,最終確定選用主從模式。因為系統(tǒng)中各個子系統(tǒng)的結構和功能是完全相同的,所以只需要先實現(xiàn)一個子節(jié)點的服務,就可以以相同的方法實現(xiàn)所有子節(jié)點的時鐘同步。
1.2 NTP原理與實現(xiàn)
本系統(tǒng)的NTP協(xié)議的對時工作是在主從工作方式下實現(xiàn)。NTP算法首先就要根據(jù)服務器和客戶端的往返報文來確定兩地時鐘的差值和報文在網(wǎng)絡中傳輸?shù)难舆t。這里定義,客戶端和時間服務器之間的時間偏差(offset)用希臘字母θ表示,對時過程中的網(wǎng)絡路徑延遲(delay)用希臘字母δ表示。
假設子節(jié)點A要向服務器方B請求時間服務。A首先要生成一個標準的NTP查詢信息包,通過網(wǎng)絡發(fā)送到B。B收到查詢信息包后,根據(jù)自己的本地時間,生成一個標準的NTP時間信息包,通過網(wǎng)絡發(fā)回給A。分布式系統(tǒng)中的NTP實現(xiàn)原理圖如圖1所示。
圖1 分布式系統(tǒng)中NTP實現(xiàn)原理圖
其中,T1為子節(jié)點A發(fā)送查詢請求時間,T2為服務器B收到查詢請求時間,T3為服務器B回復時間信息包時間,T4為子節(jié)點A接收到的時間信息包時間,T1、T2、T3和T4以客戶方的時間系統(tǒng)為參照,δ1為請求信息在網(wǎng)上傳播所消耗的時間,δ2為回復信息在網(wǎng)上傳播所消耗的時間。
其過程如下:
① 客戶端首先向時間服務器發(fā)送一個NTP 數(shù)據(jù)包,同時在數(shù)據(jù)包上打上客戶端本機的發(fā)送時間戳T1;
?、?服務器接收到客戶NTP 數(shù)據(jù)包后,同時在數(shù)據(jù)包上打上服務器本機的接收時間戳T2;
?、?服務器向客戶返回NTP 數(shù)據(jù)包后,同時在數(shù)據(jù)包上打上服務器本機的發(fā)送時間戳T3;
?、?客戶端接收到服務器返回的NTP 數(shù)據(jù)包,同時在數(shù)據(jù)包上打上客戶端接收時間戳T4。
當完成了整個過程之后,客戶端就擁有了4個時間T1~T4,并通過他們算出A與B時間上的差值,用以參考并調整客戶方時鐘。
這里設定服務器的時鐘是準確的,服務器和客戶端時鐘的時間偏差是θ,從客戶端發(fā)送報文到服務器端的路徑延遲是δ1,從服務器到客戶端的路徑延遲是δ2,路徑延遲總和是δ。 那么可以列出3個方程式:
假設從客戶端到服務器的路徑延遲和從服務器到客戶端的路徑延遲相等,即δ1=δ2=δ/2 ,以上3個方程式變?yōu)椋?br />
可以求出,服務器和客戶端時鐘的時間偏差θ=[(T2-T1)+(T3-T4)]/2,客戶端與服務器總的網(wǎng)絡路徑延遲δ=(T4-T1)-(T3-T2)。
圖2 NTP時間偏差與網(wǎng)絡延時
服務器和客戶端之間的時間差異可以從圖2中看出。
在知道了如何用NTP 算法計算精確的時間偏差值后,需要使用時間偏差值來調整本地時鐘的時間,才算完成了NTP 時間同步的全部工作。
隨著我國航天事業(yè)的飛速發(fā)展,將逐步構建多群、多任務、多功能相對獨立的測控計算機結構體系。由于實現(xiàn)功能的不同,系統(tǒng)的組織結構與操作系統(tǒng)也千差萬別,對時間精度的要求很不相同。整個系統(tǒng)必須在統(tǒng)一的時間尺度下進行工作,因此各節(jié)點之間時間的統(tǒng)一具有必要性;另一方面,當今世界寬帶網(wǎng)絡飛速發(fā)展,各種支持網(wǎng)絡系統(tǒng)也越來越多,各個網(wǎng)絡系統(tǒng)之間互聯(lián)也需要高精度、通用的時間同步。在這種狀況下,如何探索和研制簡便、可靠、準確和通用的網(wǎng)絡授時系統(tǒng)就成為迫切需要解決的問題。
要實現(xiàn)網(wǎng)絡設備時間同步,主要完成兩方面的工作內容:第一,通過某種授時方式獲取精確時間;第二,將精確時間同步到網(wǎng)絡中的每一臺設備,這也是網(wǎng)絡時間同步系統(tǒng)的設計難點。
本文將要介紹的是一種基于嵌入式實時操作系統(tǒng)VxWorks的NTP網(wǎng)絡授時服務器,其內核響應速度快,可以方便地支持實時處理,克服了以往開發(fā)網(wǎng)絡授時服務器的弊端。本文介紹了NTP服務器的原理、系統(tǒng)總體任務及其通信機制設計,并針對NTP協(xié)議運行在VxWorks下的一些問題進行了相應的改進,同時通過性能測試分析表明本系統(tǒng)的有效性。
1 NTP工作原理
1.1 NTP協(xié)議
NTP協(xié)議是通過網(wǎng)絡的通信來實現(xiàn)計算機時鐘的同步,而數(shù)據(jù)本身在網(wǎng)絡上的傳輸也是需要時間的。因此,要獲得準確的當前時間,就必須考慮網(wǎng)絡延遲造成的影響。實際上,可通過計算報文的來回程時間來估計網(wǎng)絡延遲。網(wǎng)絡時間同步的最主要問題是,如何獲得當前的準確時間。NTP通過一系列同步算法選擇精確時間,規(guī)避網(wǎng)絡延遲,保證網(wǎng)絡時間同步的安全性。
NTP 協(xié)議支持3種對時工作方式。
?、?主從模式(Server/Client mode):用戶向一個或幾個服務器提出服務請求,根據(jù)所交換的信息計算兩地時間偏差和網(wǎng)絡延遲,從中選擇認為最準確的時間偏差并調整本地的時鐘。
?、?廣播模式(Multicast/Broadcast mode):此種模式適用于高速的局域網(wǎng)中。局域網(wǎng)中的一個或多個服務器以固定的時間周期向某個多播地址廣播自己的時標,客戶端不計算時間偏差和網(wǎng)絡延遲,直接用接收到的時標修正自己的時鐘,忽略各種誤差。
③ 對稱模式(Symmetric mode):兩個以上的時間服務器互為主從進行時間消息的通信,相互校正對方的時間以維持整個同步子網(wǎng)的時間一致性。
根據(jù)本系統(tǒng)的特點,最終確定選用主從模式。因為系統(tǒng)中各個子系統(tǒng)的結構和功能是完全相同的,所以只需要先實現(xiàn)一個子節(jié)點的服務,就可以以相同的方法實現(xiàn)所有子節(jié)點的時鐘同步。
1.2 NTP原理與實現(xiàn)
本系統(tǒng)的NTP協(xié)議的對時工作是在主從工作方式下實現(xiàn)。NTP算法首先就要根據(jù)服務器和客戶端的往返報文來確定兩地時鐘的差值和報文在網(wǎng)絡中傳輸?shù)难舆t。這里定義,客戶端和時間服務器之間的時間偏差(offset)用希臘字母θ表示,對時過程中的網(wǎng)絡路徑延遲(delay)用希臘字母δ表示。
假設子節(jié)點A要向服務器方B請求時間服務。A首先要生成一個標準的NTP查詢信息包,通過網(wǎng)絡發(fā)送到B。B收到查詢信息包后,根據(jù)自己的本地時間,生成一個標準的NTP時間信息包,通過網(wǎng)絡發(fā)回給A。分布式系統(tǒng)中的NTP實現(xiàn)原理圖如圖1所示。
圖1 分布式系統(tǒng)中NTP實現(xiàn)原理圖
其中,T1為子節(jié)點A發(fā)送查詢請求時間,T2為服務器B收到查詢請求時間,T3為服務器B回復時間信息包時間,T4為子節(jié)點A接收到的時間信息包時間,T1、T2、T3和T4以客戶方的時間系統(tǒng)為參照,δ1為請求信息在網(wǎng)上傳播所消耗的時間,δ2為回復信息在網(wǎng)上傳播所消耗的時間。
其過程如下:
① 客戶端首先向時間服務器發(fā)送一個NTP 數(shù)據(jù)包,同時在數(shù)據(jù)包上打上客戶端本機的發(fā)送時間戳T1;
?、?服務器接收到客戶NTP 數(shù)據(jù)包后,同時在數(shù)據(jù)包上打上服務器本機的接收時間戳T2;
?、?服務器向客戶返回NTP 數(shù)據(jù)包后,同時在數(shù)據(jù)包上打上服務器本機的發(fā)送時間戳T3;
?、?客戶端接收到服務器返回的NTP 數(shù)據(jù)包,同時在數(shù)據(jù)包上打上客戶端接收時間戳T4。
當完成了整個過程之后,客戶端就擁有了4個時間T1~T4,并通過他們算出A與B時間上的差值,用以參考并調整客戶方時鐘。
這里設定服務器的時鐘是準確的,服務器和客戶端時鐘的時間偏差是θ,從客戶端發(fā)送報文到服務器端的路徑延遲是δ1,從服務器到客戶端的路徑延遲是δ2,路徑延遲總和是δ。 那么可以列出3個方程式:
假設從客戶端到服務器的路徑延遲和從服務器到客戶端的路徑延遲相等,即δ1=δ2=δ/2 ,以上3個方程式變?yōu)椋?br />
可以求出,服務器和客戶端時鐘的時間偏差θ=[(T2-T1)+(T3-T4)]/2,客戶端與服務器總的網(wǎng)絡路徑延遲δ=(T4-T1)-(T3-T2)。
圖2 NTP時間偏差與網(wǎng)絡延時
服務器和客戶端之間的時間差異可以從圖2中看出。
在知道了如何用NTP 算法計算精確的時間偏差值后,需要使用時間偏差值來調整本地時鐘的時間,才算完成了NTP 時間同步的全部工作。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 多功能網(wǎng)絡設備開源分享
- 解決高速網(wǎng)絡設備中電線太多的問題
- CANFD網(wǎng)絡設備通訊協(xié)議
- 中興網(wǎng)絡設備查看電源狀態(tài)檢查命令
- 《Linux設備驅動開發(fā)詳解》第16章、Linux網(wǎng)絡設備驅動 5次下載
- 無線傳感器網(wǎng)絡典型時間同步技術分析 47次下載
- 無線傳感器網(wǎng)絡時間同步綜述
- 基于嵌入式網(wǎng)絡設備的遠程監(jiān)控系統(tǒng)設計
- 設備監(jiān)測無線傳感器網(wǎng)絡時間同步算法
- 嵌入式網(wǎng)絡設備地址動態(tài)配置的研究
- 網(wǎng)絡設備監(jiān)管系統(tǒng)的設計與實現(xiàn)
- QNX操作系統(tǒng)及網(wǎng)絡設備驅動模塊
- 智能網(wǎng)絡設備開發(fā)中的硬件設計
- QNX操作系統(tǒng)及網(wǎng)絡設備驅動模塊
- 基于AX88796的嵌入式網(wǎng)絡設備驅動程序設計
- 使用Python批量連接華為網(wǎng)絡設備 203次閱讀
- 思科網(wǎng)絡設備常用show命令 414次閱讀
- 網(wǎng)絡安全隔離設備StoneWall-2000原理是什么?有哪些應用? 1946次閱讀
- 單片機的RTC獲取網(wǎng)絡時間 782次閱讀
- 不同尺度子網(wǎng)絡的模塊化神經(jīng)網(wǎng)絡同步轉換 388次閱讀
- 從零開始配置思科華為網(wǎng)絡設備,ChatGPT為你提供幫助! 761次閱讀
- 什么是零信任網(wǎng)絡的可信時間,為什么它很重要 830次閱讀
- 如何使用Python通過SNMP監(jiān)控網(wǎng)絡設備? 1148次閱讀
- 用Python寫SecureCRT批量登錄/巡檢網(wǎng)絡設備腳本 4004次閱讀
- 網(wǎng)絡時間協(xié)議的內存安全實現(xiàn) 609次閱讀
- 網(wǎng)絡設備常見的接口有哪些 9096次閱讀
- 弱電網(wǎng)絡設備交換機出現(xiàn)故障時該怎么處理 3707次閱讀
- 提供時間同步和頻率同步的IEEE1588協(xié)議的測試方法分析 3861次閱讀
- 中興通訊5G網(wǎng)絡在承載網(wǎng)中的高精度時間同步方案解析 3938次閱讀
- 利用ADSP-BF518 實現(xiàn)設備時鐘同步 1480次閱讀
下載排行
本周
- 1TPS54202H降壓轉換器評估模塊用戶指南
- 1.02MB | 7次下載 | 免費
- 2華瑞昇CR215芯片數(shù)字萬用表原理圖
- 0.21 MB | 1次下載 | 3 積分
- 3SMD LED選型目錄 燈珠手冊
- 5.36 MB | 1次下載 | 免費
- 4Tiva C系列DK-TM4C129X入門指南
- 1.69MB | 1次下載 | 免費
- 5電涌保護器(SPD)的選擇、安裝以及裝配
- 4.57 MB | 1次下載 | 免費
- 6時源芯微EMC前車燈案例
- 458.59 KB | 1次下載 | 免費
- 7bq25890、bq25892雙級聯(lián)充電器EVM(PWR692)用戶指南
- 2.02MB | 1次下載 | 免費
- 8TPS54426降壓轉換器評估模塊用戶指南
- 847.7KB | 次下載 | 免費
本月
- 1ADI高性能電源管理解決方案
- 2.43 MB | 156次下載 | 免費
- 22024PMIC市場洞察
- 2.23 MB | 63次下載 | 免費
- 3開關電源設計原理手冊
- 1.83 MB | 30次下載 | 免費
- 4智能門鎖原理圖
- 0.39 MB | 28次下載 | 免費
- 5OAH0428最新規(guī)格書(中文)
- 2.52 MB | 15次下載 | 7 積分
- 6ST7789V2單芯片控制器/驅動器英文手冊
- 3.07 MB | 9次下載 | 1 積分
- 7LTH7充電電路和鋰電池升壓5V輸出電路原理圖
- 0.04 MB | 7次下載 | 免費
- 8TPS54202H降壓轉換器評估模塊用戶指南
- 1.02MB | 7次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935119次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關降壓/升壓雙向直流/直流轉換器 PCB layout 設計
- 1.48MB | 420061次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233084次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費下載
- 340992 | 191367次下載 | 10 積分
- 5十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183334次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81581次下載 | 10 積分
- 7Keil工具MDK-Arm免費下載
- 0.02 MB | 73807次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65987次下載 | 10 積分
評論
查看更多