時間同步(NTP/PTP)技術原理介紹
時間同步(NTP/PTP)技術原理介紹
京準電子科技官微——ahjzsz
1.前言
由計算機網路系統組成的分布式系統,若想協調一致進行:IT行業的“整點開拍”、“秒殺”、“Leader選舉”,通信行業的“同步組網”之類業務處理,毫秒級甚至微秒級的時間同步是重要基礎之一,
2.術語描述
2.0 世界時
世界時UT,可以簡單理解為按照地球自轉一周來計量24小時的時間標準,由于地球自轉速率的變化,世界時的秒長會有微小的變化,每天的快慢可以達到千分之幾秒,
2.1 TAI時間
世界時不準,因此國際組織定義了TAI時間,即國際原子時( International Atomic Time),其起點是1958年的開始(世界時UT),以銫原子鐘走秒連續計時的時間,
2.2 UTC時間
計算機網路普遍使用的UTC時間(協調世界時),由國際計量局BIPM綜合全世界多個守時實驗室的鐘組計算得到,為了使UTC時間與地球自轉1天的時間(世界時UT)協調一致,每隔1到2年, BIPM會通告在UTC時間6月30榷訓12月31日最后一分鐘“加一秒”或“減一秒”等閏秒調整,也就是說,UTC時間會出現60秒或少了59秒的情況,
最近一次閏秒是UTC時間2015年6月底:
2015 年6月30日,23時 59分 59秒
2015 年6月30日,23時 59分 60秒
2015 年7月 1日, 0時 0分 0秒
由于存在閏秒,UTC時間與TAI時間是有差別的,UTC = TAI - n,這個n現在(2016年1月)是36秒,也就是說UTC時間比TAI時間慢了36秒,
2.3 北京時間
北京時間也就是東八區時間,在UTC時間基礎上加8小時,中國的北京標準時間由位于陜西的國家授時中心發播,
2.4 GPS時間
由GPS系統通過衛星信號發播的原子時間,GPS時間用自1980年1月6日零點(UTC時間)起的星期數和該星期內內的秒數來表示,
工程上,GPS接識訓會根據閏秒數將GPS時間換算為我們通常使用的UTC時間,GPS時間的源頭是美國海軍天文臺的守時原子鐘組,
2.5 北斗(BDS)時間
由北斗衛星導航系統通過衛星信號發播的原子時間,同樣,北斗接識訓會根據閏秒數將北斗時間換算為我們通常使用的UTC時間,
北斗時間的時鐘源是位于北京的解放軍時頻中心的守時原子鐘組,陜西的國家授時中心好尷尬:(,
2.6 頻率
時間的導數就是頻率,機械發條、石英晶體振蕩器、原子鐘等各種時鐘源通過產生頻率信號,按照頻率均勻打拍計數,模擬時間的等間隔流逝,就有了可見的“時間”,
2.7 頻率準確度
手表有準和不準的,反映的就是頻率準不準,時鐘頻率和標準頻率的偏差可以用頻率準確度來衡量,1E-9量級表示1秒會差1ns,我們使用的個人電腦,它的守時時鐘是個32. 768kHz的石英晶振,準確度大概只有2E-5量級(20ppm),也就是說1秒會差0.02ms,1天會跑偏大概2秒,
2.8 時間同步
廣義的“時間同步”包括的時間和頻率的同步,上級時鐘將時間頻率信號通過各種有線(以太網、SDH數字網、同軸電纜、電話等)、無線(衛星、長波、電臺、微波、WIFI、Zigbee等)鏈路傳遞給下級時鐘,下級時鐘接受時間頻率資訊后,與上級時鐘保持相位、頻率的一致,
3.時間同步原理
3.1 單向授時
上級時鐘主動發播時間資訊,下級用戶端被動接受時間資訊,并調整本地時鐘使時差控制在一定范圍內,
要想提高授時精度,用戶端必須計算出時間資訊在傳播鏈路中的延時,GPS/北斗等衛星授時,可以通過用戶端定位與衛星之間距離確定電磁傳輸延時,消除大部分誤差,而電纜、網路等如果是單向授時方式就無法準確計算單向鏈路時延了,
3.2 雙向授時
用戶端將接受的時間資訊原路回傳給上級時鐘服務端,服務端將往返時間除以二即得到單向鏈路時延,再把單向時延告訴客戶端,在此基礎上,客戶端得到服務端更準確的時間資訊,比如:北斗單向衛星授時精度100ns,雙向衛星授時精度可做到20ns,
3.3 網路時間同步
網路時間同步,特指在計算機網路內的服務器與客戶端之間利用網路報文交換實作的時間同步,
鑒于計算機網路傳輸路徑的不確定性和中間路由交換設備轉發報文時間的不確定性,通過單播或多播實作的單向網路授時是不可靠的,因此,前輩們發明的網路時間同步技術NTP/PTP等,基本原理都是通過對網路報文打時間戳(標記),往返交換報文計算傳輸時延和同步誤差,

3.4 頻率同步
頻率同步指的是主從時鐘的頻率誤差保持在一定范圍內,頻率同步有2種型別:
第1種是直接傳遞模擬頻率信號,比如用電纜或光纜傳遞10MHz、5Mhz、2.048MHz等標準頻率,或者傳遞bit位寬脈沖;
第2種是通過測量得到的主從時鐘時差,通過鎖定主從相差實作頻率鎖定(PLL),或者間接計算頻率偏差,完成頻率修正,
4.計算機網路時間同步
計算機網路時間同步只是時間同步的一種應用場景,其時間傳遞的鏈路可能是SDH網、以太網、WIFI無線網路等,
4.1 NTP
NTP(Network Time Protocol)從1985年誕生來,目前仍在在大部分的計算機網路中起著同步系統時間的作用,
- 基本原理
服務器和客戶端之間通過二次報文交換,確定主從時間誤差,客戶端校準本地計算機時間,完成時間同步,有條件的話進一步校準本地時鐘頻率,
- 時間同步程序
服務器在UDP的132埠提供授時服務,客戶端發送附帶T1時間戳(Timestamp)的查詢報文給服務器,服務器在該報文上添加到達時刻T2和回應報文發送時刻T3,客戶端記錄回應報到達時刻T4,
改個維基的圖:
- 時差計算
維基這個圖中用藍色標注了主從直接來回鏈路的時延Sigma:
Sigma =
(t4-t1)-(t3-t2)
因此,假設來回網路鏈路是對稱的,即傳輸時延相等,那么可以計算客戶端與服務器之間的時間誤差Delta為:
Delta =
t2-t1-Sigma/2=((t2-t1)+(t3-t4))/2
客戶端調整自身的時間Delta,即可完成一次時間同步,
- 計時方式
NTP采用UTC時間計時,NTP時間戳包括自1900-01-01 00:00:00開始的UTC總秒數,當前秒的亞秒數,
當正閏秒時,60秒和下一分鐘的0秒的NTP總秒數一致的,因此NTP報文專門定義了閏秒指示域來提示,
- 誤差分析
局域網內計算機利用NTP協議進行時間同步,時間同步精度在5ms左右,主要誤差包括:
1)計算機打時間戳的位置在應用層,受協議堆疊快取、任務調度等影響,不能在網路報文到來時馬上打戳;
2)各種中間網路傳輸設備帶來的傳輸時延不確定性以及鏈路的不對稱性,將進一步降低NTP時間同步精度,
4.2 PTP
為克服NTP的各種缺點,PTP(Precision Time Protocol,精確時間同步協議)應運而生,最新協議是IEEE1588v2,可實作亞微秒量級的時間同步精度,
- 基本原理
主從節點在網路鏈路層打時間戳,利用支持IEEE1588協議的PHY片,精準記錄時間同步網路報文接受或發送的時刻,交換機、路由器等網路中間節點準確記錄時間同步報文在其中停留的時間,實作對鏈路時延的準確計算,
- 時間同步程序
PTP默認使用組播協議,二層或四層UDP組播都可以,一般我們使用基于UDP組播,使用319和320兩個埠,
PTP定義了三種角色:OC、BC和TC,我們一般接觸的是OC:主時鐘和從時鐘,交換機、路由器一般是BC或TC,
由于硬體性能有限,網路報文發送時記錄的時刻資訊,可以在隨后的Follow_Up跟隨報文中發出,這就是PTP的雙步模式(Two-step),
下圖是兩OC主從時鐘之間的同步程序:
- a.主時鐘向從時鐘發送Sync報文,并在本地記錄發送時間t1;從時鐘收到該報文后,記錄接收時間t2,
- b.時鐘發送Sync報文之后,緊接著發送一個攜帶有t1的Follow_Up報文,
- c.從時鐘向主時鐘發送Delay_Req報文,用于發起反向傳輸延時的計算,并在本地記錄發送時間t3;主時鐘收到該報文后,記錄接收時間t4,
- d.主時鐘收到Delay_Req報文之后,回復一個攜帶有t4的Delay_Resp報文,
- 時差計算
與NTP一樣的原理,從時鐘根據擁有的t1~t4這四個時間戳,由此可計算出主、從時鐘間的往返總延時為:
Sigma =
(t4-t1)-(t3-t2)
假設網路是對稱的,從時鐘相對于主時鐘的時鐘偏差為:
Delta =
t2-t1-Sigma/2=((t2-t1)+(t3-t4))/2
- 計時方式
與NTP不同,PTP采用TAI世界原子時間計時,而且PTP計時的起點與unix時間一致,即UTC時間1970年1月1日0點,
PTP主鐘會告知從鐘,當前UTC相對于TAI的累計偏移量,從鐘據此計算當前準確的UTC時間,
- 誤差分析
PTP能準確記錄報文發送和接受的時間,也能計算中間鏈路的延時,剩下影響最大的就是網路鏈路的不對稱性了,
在實際工程中,網路中間鏈路設備不支持PTP協議,大大降低了PTP的同步精度,目前,PTP主要應用在通信同步網、電力同步網等行業網路系統里,
- 同步拓撲
PTP域中所有的時鐘節點都按一定層次組織在一起,可通過BMC(Best Master Clock,最佳主時鐘)協議動態選舉出最優時鐘,最優時鐘的時間最終將被同步到整個PTP域中,
BMC演算法與STP(Spaning Tree Protocl)生成樹協議類似,最終形成無環路的樹形網路拓撲,且都是動態選舉,能適應最佳主時鐘切換的變化,
- 擴展應用——PTP over SDH
充分利用各行業已有的SDH通信網路,利用PTP-E1信號轉換設備,架設PTP同步網路,除了需要考慮鏈路倒換問題之外,SDH網路的時延穩定性可大幅提升網路時間同步精度,
4.3 SyncE同步以太網
以太網最早只能傳輸資料信號,有另外獨立的頻率同步網路,隨著以太網的快速發展,SyncE(Synchronized Ethernet)同步以太網技術誕生后,企業們有了新的選擇,
- 基本原理
時鐘節點利用以太網(1000M、1G、10G等)物理層的空閑間隙,傳遞位寬時鐘信號,實作時鐘頻率信號(25M、125M等)的自上而下傳遞,
- 協議控制
類似于SDH網路等時間間隔傳遞的SSM同步狀態資訊,同步以太網(Sync-E)利用鏈路層ESMC協議封裝傳遞SSM資訊,SSM資訊包含時鐘質量資訊,接收端據此選擇合適的上級網路時鐘,
- 應用
一般商業PHY片提供SyncE功能選項,開啟該功能模式,即可利用PHY恢復出來的頻率信號,校準本地時鐘頻率或分頻后用于本地計時,
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/285863.html
標籤:訊息安全
上一篇:mysql無列名注入
