資料介紹
引言
隨著我國航天事業(yè)的飛速發(fā)展,將逐步構(gòu)建多群、多任務(wù)、多功能相對獨(dú)立的測控計(jì)算機(jī)結(jié)構(gòu)體系。由于實(shí)現(xiàn)功能的不同,系統(tǒng)的組織結(jié)構(gòu)與操作系統(tǒng)也千差萬別,對時(shí)間精度的要求很不相同。整個(gè)系統(tǒng)必須在統(tǒng)一的時(shí)間尺度下進(jìn)行工作,因此各節(jié)點(diǎn)之間時(shí)間的統(tǒng)一具有必要性;另一方面,當(dāng)今世界寬帶網(wǎng)絡(luò)飛速發(fā)展,各種支持網(wǎng)絡(luò)系統(tǒng)也越來越多,各個(gè)網(wǎng)絡(luò)系統(tǒng)之間互聯(lián)也需要高精度、通用的時(shí)間同步。在這種狀況下,如何探索和研制簡便、可靠、準(zhǔn)確和通用的網(wǎng)絡(luò)授時(shí)系統(tǒng)就成為迫切需要解決的問題。
要實(shí)現(xiàn)網(wǎng)絡(luò)設(shè)備時(shí)間同步,主要完成兩方面的工作內(nèi)容:第一,通過某種授時(shí)方式獲取精確時(shí)間;第二,將精確時(shí)間同步到網(wǎng)絡(luò)中的每一臺(tái)設(shè)備,這也是網(wǎng)絡(luò)時(shí)間同步系統(tǒng)的設(shè)計(jì)難點(diǎn)。
本文將要介紹的是一種基于嵌入式實(shí)時(shí)操作系統(tǒng)VxWorks的NTP網(wǎng)絡(luò)授時(shí)服務(wù)器,其內(nèi)核響應(yīng)速度快,可以方便地支持實(shí)時(shí)處理,克服了以往開發(fā)網(wǎng)絡(luò)授時(shí)服務(wù)器的弊端。本文介紹了NTP服務(wù)器的原理、系統(tǒng)總體任務(wù)及其通信機(jī)制設(shè)計(jì),并針對NTP協(xié)議運(yùn)行在VxWorks下的一些問題進(jìn)行了相應(yīng)的改進(jìn),同時(shí)通過性能測試分析表明本系統(tǒng)的有效性。
1 NTP工作原理
1.1 NTP協(xié)議
NTP協(xié)議是通過網(wǎng)絡(luò)的通信來實(shí)現(xiàn)計(jì)算機(jī)時(shí)鐘的同步,而數(shù)據(jù)本身在網(wǎng)絡(luò)上的傳輸也是需要時(shí)間的。因此,要獲得準(zhǔn)確的當(dāng)前時(shí)間,就必須考慮網(wǎng)絡(luò)延遲造成的影響。實(shí)際上,可通過計(jì)算報(bào)文的來回程時(shí)間來估計(jì)網(wǎng)絡(luò)延遲。網(wǎng)絡(luò)時(shí)間同步的最主要問題是,如何獲得當(dāng)前的準(zhǔn)確時(shí)間。NTP通過一系列同步算法選擇精確時(shí)間,規(guī)避網(wǎng)絡(luò)延遲,保證網(wǎng)絡(luò)時(shí)間同步的安全性。
NTP 協(xié)議支持3種對時(shí)工作方式。
① 主從模式(Server/Client mode):用戶向一個(gè)或幾個(gè)服務(wù)器提出服務(wù)請求,根據(jù)所交換的信息計(jì)算兩地時(shí)間偏差和網(wǎng)絡(luò)延遲,從中選擇認(rèn)為最準(zhǔn)確的時(shí)間偏差并調(diào)整本地的時(shí)鐘。
② 廣播模式(Multicast/Broadcast mode):此種模式適用于高速的局域網(wǎng)中。局域網(wǎng)中的一個(gè)或多個(gè)服務(wù)器以固定的時(shí)間周期向某個(gè)多播地址廣播自己的時(shí)標(biāo),客戶端不計(jì)算時(shí)間偏差和網(wǎng)絡(luò)延遲,直接用接收到的時(shí)標(biāo)修正自己的時(shí)鐘,忽略各種誤差。
③ 對稱模式(Symmetric mode):兩個(gè)以上的時(shí)間服務(wù)器互為主從進(jìn)行時(shí)間消息的通信,相互校正對方的時(shí)間以維持整個(gè)同步子網(wǎng)的時(shí)間一致性。
根據(jù)本系統(tǒng)的特點(diǎn),最終確定選用主從模式。因?yàn)橄到y(tǒng)中各個(gè)子系統(tǒng)的結(jié)構(gòu)和功能是完全相同的,所以只需要先實(shí)現(xiàn)一個(gè)子節(jié)點(diǎn)的服務(wù),就可以以相同的方法實(shí)現(xiàn)所有子節(jié)點(diǎn)的時(shí)鐘同步。
1.2 NTP原理與實(shí)現(xiàn)
本系統(tǒng)的NTP協(xié)議的對時(shí)工作是在主從工作方式下實(shí)現(xiàn)。NTP算法首先就要根據(jù)服務(wù)器和客戶端的往返報(bào)文來確定兩地時(shí)鐘的差值和報(bào)文在網(wǎng)絡(luò)中傳輸?shù)难舆t。這里定義,客戶端和時(shí)間服務(wù)器之間的時(shí)間偏差(offset)用希臘字母θ表示,對時(shí)過程中的網(wǎng)絡(luò)路徑延遲(delay)用希臘字母δ表示。
假設(shè)子節(jié)點(diǎn)A要向服務(wù)器方B請求時(shí)間服務(wù)。A首先要生成一個(gè)標(biāo)準(zhǔn)的NTP查詢信息包,通過網(wǎng)絡(luò)發(fā)送到B。B收到查詢信息包后,根據(jù)自己的本地時(shí)間,生成一個(gè)標(biāo)準(zhǔn)的NTP時(shí)間信息包,通過網(wǎng)絡(luò)發(fā)回給A。分布式系統(tǒng)中的NTP實(shí)現(xiàn)原理圖如圖1所示。
圖1 分布式系統(tǒng)中NTP實(shí)現(xiàn)原理圖
其中,T1為子節(jié)點(diǎn)A發(fā)送查詢請求時(shí)間,T2為服務(wù)器B收到查詢請求時(shí)間,T3為服務(wù)器B回復(fù)時(shí)間信息包時(shí)間,T4為子節(jié)點(diǎn)A接收到的時(shí)間信息包時(shí)間,T1、T2、T3和T4以客戶方的時(shí)間系統(tǒng)為參照,δ1為請求信息在網(wǎng)上傳播所消耗的時(shí)間,δ2為回復(fù)信息在網(wǎng)上傳播所消耗的時(shí)間。
其過程如下:
① 客戶端首先向時(shí)間服務(wù)器發(fā)送一個(gè)NTP 數(shù)據(jù)包,同時(shí)在數(shù)據(jù)包上打上客戶端本機(jī)的發(fā)送時(shí)間戳T1;
② 服務(wù)器接收到客戶NTP 數(shù)據(jù)包后,同時(shí)在數(shù)據(jù)包上打上服務(wù)器本機(jī)的接收時(shí)間戳T2;
③ 服務(wù)器向客戶返回NTP 數(shù)據(jù)包后,同時(shí)在數(shù)據(jù)包上打上服務(wù)器本機(jī)的發(fā)送時(shí)間戳T3;
④ 客戶端接收到服務(wù)器返回的NTP 數(shù)據(jù)包,同時(shí)在數(shù)據(jù)包上打上客戶端接收時(shí)間戳T4。
當(dāng)完成了整個(gè)過程之后,客戶端就擁有了4個(gè)時(shí)間T1~T4,并通過他們算出A與B時(shí)間上的差值,用以參考并調(diào)整客戶方時(shí)鐘。
這里設(shè)定服務(wù)器的時(shí)鐘是準(zhǔn)確的,服務(wù)器和客戶端時(shí)鐘的時(shí)間偏差是θ,從客戶端發(fā)送報(bào)文到服務(wù)器端的路徑延遲是δ1,從服務(wù)器到客戶端的路徑延遲是δ2,路徑延遲總和是δ。 那么可以列出3個(gè)方程式:
假設(shè)從客戶端到服務(wù)器的路徑延遲和從服務(wù)器到客戶端的路徑延遲相等,即δ1=δ2=δ/2 ,以上3個(gè)方程式變?yōu)椋?br />
可以求出,服務(wù)器和客戶端時(shí)鐘的時(shí)間偏差θ=[(T2-T1)+(T3-T4)]/2,客戶端與服務(wù)器總的網(wǎng)絡(luò)路徑延遲δ=(T4-T1)-(T3-T2)。
圖2 NTP時(shí)間偏差與網(wǎng)絡(luò)延時(shí)
服務(wù)器和客戶端之間的時(shí)間差異可以從圖2中看出。
在知道了如何用NTP 算法計(jì)算精確的時(shí)間偏差值后,需要使用時(shí)間偏差值來調(diào)整本地時(shí)鐘的時(shí)間,才算完成了NTP 時(shí)間同步的全部工作。
隨著我國航天事業(yè)的飛速發(fā)展,將逐步構(gòu)建多群、多任務(wù)、多功能相對獨(dú)立的測控計(jì)算機(jī)結(jié)構(gòu)體系。由于實(shí)現(xiàn)功能的不同,系統(tǒng)的組織結(jié)構(gòu)與操作系統(tǒng)也千差萬別,對時(shí)間精度的要求很不相同。整個(gè)系統(tǒng)必須在統(tǒng)一的時(shí)間尺度下進(jìn)行工作,因此各節(jié)點(diǎn)之間時(shí)間的統(tǒng)一具有必要性;另一方面,當(dāng)今世界寬帶網(wǎng)絡(luò)飛速發(fā)展,各種支持網(wǎng)絡(luò)系統(tǒng)也越來越多,各個(gè)網(wǎng)絡(luò)系統(tǒng)之間互聯(lián)也需要高精度、通用的時(shí)間同步。在這種狀況下,如何探索和研制簡便、可靠、準(zhǔn)確和通用的網(wǎng)絡(luò)授時(shí)系統(tǒng)就成為迫切需要解決的問題。
要實(shí)現(xiàn)網(wǎng)絡(luò)設(shè)備時(shí)間同步,主要完成兩方面的工作內(nèi)容:第一,通過某種授時(shí)方式獲取精確時(shí)間;第二,將精確時(shí)間同步到網(wǎng)絡(luò)中的每一臺(tái)設(shè)備,這也是網(wǎng)絡(luò)時(shí)間同步系統(tǒng)的設(shè)計(jì)難點(diǎn)。
本文將要介紹的是一種基于嵌入式實(shí)時(shí)操作系統(tǒng)VxWorks的NTP網(wǎng)絡(luò)授時(shí)服務(wù)器,其內(nèi)核響應(yīng)速度快,可以方便地支持實(shí)時(shí)處理,克服了以往開發(fā)網(wǎng)絡(luò)授時(shí)服務(wù)器的弊端。本文介紹了NTP服務(wù)器的原理、系統(tǒng)總體任務(wù)及其通信機(jī)制設(shè)計(jì),并針對NTP協(xié)議運(yùn)行在VxWorks下的一些問題進(jìn)行了相應(yīng)的改進(jìn),同時(shí)通過性能測試分析表明本系統(tǒng)的有效性。
1 NTP工作原理
1.1 NTP協(xié)議
NTP協(xié)議是通過網(wǎng)絡(luò)的通信來實(shí)現(xiàn)計(jì)算機(jī)時(shí)鐘的同步,而數(shù)據(jù)本身在網(wǎng)絡(luò)上的傳輸也是需要時(shí)間的。因此,要獲得準(zhǔn)確的當(dāng)前時(shí)間,就必須考慮網(wǎng)絡(luò)延遲造成的影響。實(shí)際上,可通過計(jì)算報(bào)文的來回程時(shí)間來估計(jì)網(wǎng)絡(luò)延遲。網(wǎng)絡(luò)時(shí)間同步的最主要問題是,如何獲得當(dāng)前的準(zhǔn)確時(shí)間。NTP通過一系列同步算法選擇精確時(shí)間,規(guī)避網(wǎng)絡(luò)延遲,保證網(wǎng)絡(luò)時(shí)間同步的安全性。
NTP 協(xié)議支持3種對時(shí)工作方式。
① 主從模式(Server/Client mode):用戶向一個(gè)或幾個(gè)服務(wù)器提出服務(wù)請求,根據(jù)所交換的信息計(jì)算兩地時(shí)間偏差和網(wǎng)絡(luò)延遲,從中選擇認(rèn)為最準(zhǔn)確的時(shí)間偏差并調(diào)整本地的時(shí)鐘。
② 廣播模式(Multicast/Broadcast mode):此種模式適用于高速的局域網(wǎng)中。局域網(wǎng)中的一個(gè)或多個(gè)服務(wù)器以固定的時(shí)間周期向某個(gè)多播地址廣播自己的時(shí)標(biāo),客戶端不計(jì)算時(shí)間偏差和網(wǎng)絡(luò)延遲,直接用接收到的時(shí)標(biāo)修正自己的時(shí)鐘,忽略各種誤差。
③ 對稱模式(Symmetric mode):兩個(gè)以上的時(shí)間服務(wù)器互為主從進(jìn)行時(shí)間消息的通信,相互校正對方的時(shí)間以維持整個(gè)同步子網(wǎng)的時(shí)間一致性。
根據(jù)本系統(tǒng)的特點(diǎn),最終確定選用主從模式。因?yàn)橄到y(tǒng)中各個(gè)子系統(tǒng)的結(jié)構(gòu)和功能是完全相同的,所以只需要先實(shí)現(xiàn)一個(gè)子節(jié)點(diǎn)的服務(wù),就可以以相同的方法實(shí)現(xiàn)所有子節(jié)點(diǎn)的時(shí)鐘同步。
1.2 NTP原理與實(shí)現(xiàn)
本系統(tǒng)的NTP協(xié)議的對時(shí)工作是在主從工作方式下實(shí)現(xiàn)。NTP算法首先就要根據(jù)服務(wù)器和客戶端的往返報(bào)文來確定兩地時(shí)鐘的差值和報(bào)文在網(wǎng)絡(luò)中傳輸?shù)难舆t。這里定義,客戶端和時(shí)間服務(wù)器之間的時(shí)間偏差(offset)用希臘字母θ表示,對時(shí)過程中的網(wǎng)絡(luò)路徑延遲(delay)用希臘字母δ表示。
假設(shè)子節(jié)點(diǎn)A要向服務(wù)器方B請求時(shí)間服務(wù)。A首先要生成一個(gè)標(biāo)準(zhǔn)的NTP查詢信息包,通過網(wǎng)絡(luò)發(fā)送到B。B收到查詢信息包后,根據(jù)自己的本地時(shí)間,生成一個(gè)標(biāo)準(zhǔn)的NTP時(shí)間信息包,通過網(wǎng)絡(luò)發(fā)回給A。分布式系統(tǒng)中的NTP實(shí)現(xiàn)原理圖如圖1所示。
圖1 分布式系統(tǒng)中NTP實(shí)現(xiàn)原理圖
其中,T1為子節(jié)點(diǎn)A發(fā)送查詢請求時(shí)間,T2為服務(wù)器B收到查詢請求時(shí)間,T3為服務(wù)器B回復(fù)時(shí)間信息包時(shí)間,T4為子節(jié)點(diǎn)A接收到的時(shí)間信息包時(shí)間,T1、T2、T3和T4以客戶方的時(shí)間系統(tǒng)為參照,δ1為請求信息在網(wǎng)上傳播所消耗的時(shí)間,δ2為回復(fù)信息在網(wǎng)上傳播所消耗的時(shí)間。
其過程如下:
① 客戶端首先向時(shí)間服務(wù)器發(fā)送一個(gè)NTP 數(shù)據(jù)包,同時(shí)在數(shù)據(jù)包上打上客戶端本機(jī)的發(fā)送時(shí)間戳T1;
② 服務(wù)器接收到客戶NTP 數(shù)據(jù)包后,同時(shí)在數(shù)據(jù)包上打上服務(wù)器本機(jī)的接收時(shí)間戳T2;
③ 服務(wù)器向客戶返回NTP 數(shù)據(jù)包后,同時(shí)在數(shù)據(jù)包上打上服務(wù)器本機(jī)的發(fā)送時(shí)間戳T3;
④ 客戶端接收到服務(wù)器返回的NTP 數(shù)據(jù)包,同時(shí)在數(shù)據(jù)包上打上客戶端接收時(shí)間戳T4。
當(dāng)完成了整個(gè)過程之后,客戶端就擁有了4個(gè)時(shí)間T1~T4,并通過他們算出A與B時(shí)間上的差值,用以參考并調(diào)整客戶方時(shí)鐘。
這里設(shè)定服務(wù)器的時(shí)鐘是準(zhǔn)確的,服務(wù)器和客戶端時(shí)鐘的時(shí)間偏差是θ,從客戶端發(fā)送報(bào)文到服務(wù)器端的路徑延遲是δ1,從服務(wù)器到客戶端的路徑延遲是δ2,路徑延遲總和是δ。 那么可以列出3個(gè)方程式:
假設(shè)從客戶端到服務(wù)器的路徑延遲和從服務(wù)器到客戶端的路徑延遲相等,即δ1=δ2=δ/2 ,以上3個(gè)方程式變?yōu)椋?br />
可以求出,服務(wù)器和客戶端時(shí)鐘的時(shí)間偏差θ=[(T2-T1)+(T3-T4)]/2,客戶端與服務(wù)器總的網(wǎng)絡(luò)路徑延遲δ=(T4-T1)-(T3-T2)。
圖2 NTP時(shí)間偏差與網(wǎng)絡(luò)延時(shí)
服務(wù)器和客戶端之間的時(shí)間差異可以從圖2中看出。
在知道了如何用NTP 算法計(jì)算精確的時(shí)間偏差值后,需要使用時(shí)間偏差值來調(diào)整本地時(shí)鐘的時(shí)間,才算完成了NTP 時(shí)間同步的全部工作。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 多功能網(wǎng)絡(luò)設(shè)備開源分享
- 解決高速網(wǎng)絡(luò)設(shè)備中電線太多的問題
- CANFD網(wǎng)絡(luò)設(shè)備通訊協(xié)議
- 中興網(wǎng)絡(luò)設(shè)備查看電源狀態(tài)檢查命令
- 《Linux設(shè)備驅(qū)動(dòng)開發(fā)詳解》第16章、Linux網(wǎng)絡(luò)設(shè)備驅(qū)動(dòng) 5次下載
- 無線傳感器網(wǎng)絡(luò)典型時(shí)間同步技術(shù)分析 47次下載
- 無線傳感器網(wǎng)絡(luò)時(shí)間同步綜述
- 基于嵌入式網(wǎng)絡(luò)設(shè)備的遠(yuǎn)程監(jiān)控系統(tǒng)設(shè)計(jì)
- 設(shè)備監(jiān)測無線傳感器網(wǎng)絡(luò)時(shí)間同步算法
- 嵌入式網(wǎng)絡(luò)設(shè)備地址動(dòng)態(tài)配置的研究
- 網(wǎng)絡(luò)設(shè)備監(jiān)管系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
- QNX操作系統(tǒng)及網(wǎng)絡(luò)設(shè)備驅(qū)動(dòng)模塊
- 智能網(wǎng)絡(luò)設(shè)備開發(fā)中的硬件設(shè)計(jì)
- QNX操作系統(tǒng)及網(wǎng)絡(luò)設(shè)備驅(qū)動(dòng)模塊
- 基于AX88796的嵌入式網(wǎng)絡(luò)設(shè)備驅(qū)動(dòng)程序設(shè)計(jì)
- 使用Python批量連接華為網(wǎng)絡(luò)設(shè)備 203次閱讀
- 思科網(wǎng)絡(luò)設(shè)備常用show命令 414次閱讀
- 網(wǎng)絡(luò)安全隔離設(shè)備StoneWall-2000原理是什么?有哪些應(yīng)用? 1946次閱讀
- 單片機(jī)的RTC獲取網(wǎng)絡(luò)時(shí)間 782次閱讀
- 不同尺度子網(wǎng)絡(luò)的模塊化神經(jīng)網(wǎng)絡(luò)同步轉(zhuǎn)換 388次閱讀
- 從零開始配置思科華為網(wǎng)絡(luò)設(shè)備,ChatGPT為你提供幫助! 761次閱讀
- 什么是零信任網(wǎng)絡(luò)的可信時(shí)間,為什么它很重要 830次閱讀
- 如何使用Python通過SNMP監(jiān)控網(wǎng)絡(luò)設(shè)備? 1148次閱讀
- 用Python寫SecureCRT批量登錄/巡檢網(wǎng)絡(luò)設(shè)備腳本 4004次閱讀
- 網(wǎng)絡(luò)時(shí)間協(xié)議的內(nèi)存安全實(shí)現(xiàn) 609次閱讀
- 網(wǎng)絡(luò)設(shè)備常見的接口有哪些 9096次閱讀
- 弱電網(wǎng)絡(luò)設(shè)備交換機(jī)出現(xiàn)故障時(shí)該怎么處理 3707次閱讀
- 提供時(shí)間同步和頻率同步的IEEE1588協(xié)議的測試方法分析 3861次閱讀
- 中興通訊5G網(wǎng)絡(luò)在承載網(wǎng)中的高精度時(shí)間同步方案解析 3938次閱讀
- 利用ADSP-BF518 實(shí)現(xiàn)設(shè)備時(shí)鐘同步 1480次閱讀
下載排行
本周
- 1TC358743XBG評(píng)估板參考手冊
- 1.36 MB | 330次下載 | 免費(fèi)
- 2開關(guān)電源基礎(chǔ)知識(shí)
- 5.73 MB | 6次下載 | 免費(fèi)
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設(shè)計(jì)
- 0.60 MB | 3次下載 | 免費(fèi)
- 5基于FPGA的光纖通信系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
- 0.61 MB | 2次下載 | 免費(fèi)
- 6基于FPGA的C8051F單片機(jī)開發(fā)板設(shè)計(jì)
- 0.70 MB | 2次下載 | 免費(fèi)
- 751單片機(jī)窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費(fèi)
- 8基于51單片機(jī)的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33564次下載 | 免費(fèi)
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費(fèi)
- 4開關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21548次下載 | 免費(fèi)
- 5電氣工程師手冊免費(fèi)下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費(fèi)
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費(fèi)
- 7電子制作實(shí)例集錦 下載
- 未知 | 8113次下載 | 免費(fèi)
- 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德爾著
- 0.00 MB | 6653次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537796次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191185次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183278次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138040次下載 | 免費(fèi)
評(píng)論
查看更多