网络时间协定

✍ dations ◷ 2025-01-23 09:30:08 #网络时间协定
网络时间协议(英语:Network Time Protocol,缩写:NTP)是在数据网络潜伏时间可变的计算机系统之间通过分组交换进行时钟同步的一个网络协议,位于OSI模型的应用层。自1985年以来,NTP是当前仍在使用的最古老的互联网协议之一。NTP由特拉华大学的David L. Mills(英语:David L. Mills)设计。NTP意图将所有参与计算机的协调世界时(UTC)时间同步到几毫秒的误差内。:3它使用Marzullo算法(英语:Marzullo's algorithm)的修改版来选择准确的时间服务器,其设计旨在减轻可变网络延迟(英语:network latency)造成的影响。NTP通常可以在公共互联网保持几十毫秒的误差,并且在理想的局域网环境中可以实现超过1毫秒的精度。不对称路由和拥塞控制可能导致100毫秒(或更高)的错误。该协议通常描述为一种主从式架构,但它也可以用在点对点网络中,对等体双方可将另一端认定为潜在的时间源。:20发送和接收时间戳采用用户数据报协议(UDP)的端口123实现。这也可以使用广播或多播,其中的客户端在最初的往返校准交换后被动地监听时间更新。NTP提供一个即将到来闰秒调整的警告,但不会传输有关本地时区或夏时制的信息。当前协议为版本4(NTPv4),这是一个RFC 5905文档中的建议标准。它向下兼容指定于RFC 1305的版本3。1979年,网络时间同步技术在纽约的国家计算机会议(英语:National Computer Conference)上于运行在跨大西洋卫星网络的互联网服务上公开演示,这可能是该技术的首次公开演示。该技术后在1981年互联网工程笔记(IEN)173中描述,并根据RFC 778文档开发为一个公开协议。该技术首先被部署在一个本地网络,作为Hello路由协议的一部分,并在Fuzzball(英语:Fuzzball router)(一个用于网络原型的实验操作系统,已运行多年)中实现。现在还有其他的相关网络工具。这包括Daytime和Time协议用以记录事件时间,以及互联网控制消息协议和IP时间戳选项(RFC 781)。更多完整的同步系统,虽然缺乏NTP的数据分析和时钟规律算法,包括Unix守护进程timed在内的软件其使用选举算法为所有客户端指定服务器。以及数字时间同步服务(Digital Time Synchronization Service,DTSS)使用类似构NTP阶层模型的服务器层次结构。1985年,NTPv0被实现于Fuzzball和Unix,文档化于RFC 958的NTP数据包头、和往返延迟和偏移计算都被留存至NTPv4。尽管当时可用的计算机和网络相对较慢,但在跨大西洋链路上也获取了优于100毫秒的精度,在以太网网络上准确度为几十毫秒。1988年,一个更完整的NTPv1协议规范及相关的算法发表在RFC 1059。它利用了RFC 956的文献中的实验结果和时钟滤波算法,并是第一个描述客户端-服务器和点对点网络模型的版本。1991年,NTPv1架构、协议和算法通过David L. Mills(英语:David L. Mills)在IEEE Transactions on Communications(英语:IEEE Transactions on Communications)发布的一篇文章得到了工程学界的更广泛关注。1989年,RFC 1119发布通过有限状态机定义的NTPv2,使用伪代码来描述其操作。它引入了一个管理协议和加密认证方案,它们留存至NTPv4。社区批评NTP的设计缺乏形式正确性原则(英语:Correctness (computer science))。他们的替代设计包括Marzullo算法(英语:Marzullo's algorithm),其修改版本已及时添加到NTP。这个时代的大多数算法也大部分留存至NTPv4。1992年,RFC 1305定义了NTPv3。该RFC包括一个对所有错误来源的分析,从参考时钟(英语:Master clock)至最终客户端,这使帮助度量和选择最佳服务器成为可能(在其中几个候选者反对的情况下)。广播模式被引入。在接下来的几年里,随着新特性的添加和算法的改进,显然还需要一个新的协议版本。2010年,RFC 5905发布了一个对NTPv4的建议规范,但该协议自那时以来已经显著改变,截至2014年,更新的RFC尚未发布。在Mills从特拉华大学退休后,该参考实现当前由Harlan Stenn保持为一个开放源代码项目。NTP使用一个分层、半分层的时间源系统。该层次的每个级别被称为“stratum”,顶层分配为数字0。一个通过阶层n同步的服务器将运行在阶层n + 1。数字表示与参考时钟的距离,用于防止层次结构中的循环依赖性。阶层并不总是指示质量或可靠性;在阶层3的时间源得到比阶层2时间源更高的时间质量也很常见。电信系统对时钟层(英语:Synchronization in telecommunications)使用不同的定义。以下提供了阶层0、1、2、3的简要描述。阶层的上限为15;阶层16被用于标识设备未同步。每台计算机上的NTP算法相互构造一个贝尔曼-福特算法最短路径生成树,以最小化所有客户端到阶层1服务器的累积往返延迟。:20NTP使用64比特的时间戳,其中32位表示秒,32位表示秒的小数,给出一个每232秒(136年)才会翻转(英语:Integer overflow)的时间尺度,理论分辨率2−32秒(233皮秒)。NTP以1900年1月1日作为开始时间,因此第一次翻转将在2036年2月7日发生。NTP的未来版本可能将时间表示扩展到128位:其中64位表示秒,64位表示秒的小数。当前的NTPv4格式支持“时代数字”(Era Number)和“时代偏移”(Era Offset),正确使用它们应该有助于解决日期翻转问题。据Mills称:“64位的秒小数足以分辨光子以光速通过电子所需的时间。64位的秒足以提供明确的时间表示,直到宇宙变暗。”典型的NTP客户端将定期轮询不同网络上的三个或更多服务器。为同步其时钟,客户端必须计算其时间偏移量和来回通信延迟。时间偏移“θ”定义为:往返延迟“δ”为:其中:“θ”和“δ”的值通过过滤器并进行统计分析。异常值(英语:Outliers)被剔除,并从最好的三个剩余候选中导出估算的时间偏移。然后调整时钟频率以逐渐减小偏移,创建一个反馈回路。:20当客户端和服务器之间的输入和输出路由都具有对称的标称延迟时,同步是正确的。如果路由没有共同的标称延迟,则将差异取半作为测量误差。NTP参考实现(英语:reference implementation)连同协议的开发已持续发展了20多年。随着新功能的添加,向后兼容性仍保持不变。它包含几个敏感的算法,尤其是时钟规律,在同步到使用不同算法的服务器时可能会发生错误。该软件已移植到几乎各个计算平台,包括个人计算机。:13它在Unix上运行名为ntpd(英语:ntpd)的守护进程,或在Windows上运行为一个Windows服务。:15支持参考时钟,并且以与远程服务器相同的方式对偏移进行过滤和分析,尽管它们通常更频繁地轮询。:19一个不太复杂的NTP实现,使用相同的协议但不需要存储较长时间的状态(英语:state (computer science)),也称简单网络时间协议(Simple Network Time Protocol,SNTP)。它使用在某些嵌入式系统和不需要高精度时间的应用中。从Windows 2000起的所有Microsoft Windows版本都包括Windows时间服务(W32Time),其具有将计算机时钟同步到NTP服务器的能力。W32Time服务最初是为实现Kerberos第五版的身份验证协议,它需要误差5分钟内正确时间值以防止重放攻击。Windows 2000和Windows XP中只实现了简单的NTP,并在几个方面违反了NTP第3版的标准。从Windows Server 2003和Windows Vista开始,已包括符合完整NTP的实现。微软称W32Time服务不能可靠地将同步时间保持在1至2秒的范围内。如果需要更高的精度,微软建议使用其他NTP实现。Windows Server 2016现在在某些操作条件下支持1ms的时间精度。一个新的NTP客户端ntimed由Poul-Henning Kamp(英语:Poul-Henning Kamp)在2014年开始编写。新的实现由Linux基金会赞助,作为参考实现的一个替代,因为它决定更容易地从头开始编写新的实现,而不是修复现有大型代码库的现有问题。截至2015年6月,它尚未正式发布,但ntimed可以可靠地同步时钟。ntimed在Debian和FreeBSD上工作,但也被移植到Windows和Mac OS。在闰秒事件的当天,ntpd从配置文件、附加参考时钟或远程服务器收到通知。因为时间必须是单调递增,所以闰秒的插入方式为:23:59:59、23:59:60、00:00:00。虽然时钟实际上在事件期间停止,但任何查询系统时间的进程都会使它增加微小的量,以保持事件的顺序。如果必要,在序列中删除闰秒的形式为:23:59:58、00:00:00,跳过23:59:59。2014年底,几个安全问题被发现。在以前,研究人员发现NTP服务器可能受到中间人攻击的影响,除非数据包被加密和签名以验证身份。但这所涉及的计算量在繁忙的服务器上可能是不切实际的,尤其是容易遭遇拒绝服务攻击。NTP消息欺骗可以被用来偏移客户端计算机上的时钟,并配合过期的加密密钥来完成其他攻击。可能受到伪造NTP消息影响的服务包括TLS、DNSSEC、各类缓存方案(例如DNS缓存)、比特币以及许多持久登录方案。有着25年以上历史的NTP代码库中的参考实现中只发现了几个其他的安全问题,但最近出现的几个引起了人们的强烈关注。该协议正在对其整个历史进行修订和审查。截至2011年1月,在NTP规范中没有安全修订,也没有在CERT(英语:CERT Coordination Center)的报告。几年来,该参考实现的当前代码库已经被多个来源进行安全审计,在当前发布的软件中没有已知的高风险漏洞。多种NTP服务器误用和滥用(英语:NTP server misuse and abuse)实践的存在导致了对网络时间协议(NTP)服务器的破坏或劣化。NTP已经被用于分布式拒绝服务(DDoS)攻击,方法是将一个具有伪造的返回地址的小的查询发送到NTP服务器。类似DNS放大攻击,服务器将以比攻击者发送数据量大很多倍的数据量回复给伪造的目标。为了避免参与攻击,服务器可以配置为忽略外部查询,或者升级到4.2.7p26或更高版本。一个缓存溢出漏洞已经被发现,并自2014年12月19日提供补丁。漏洞覆盖NTP第四版所有版本,自4.2.8修复。苹果公司首次使用自动更新功能解决该问题,不过这只适用最近的MacOS版本。在10.6.8版本中,用户可以手动修复服务器版本,以及普通用户可以在系统首选项-日期和时间中关闭自动更新时间。研究人员认为该协议的设计是相当好的,缺陷出现在协议的实现中。某些错误很基础,例如例程中缺少返回语句,这可能导致某些运行在root权限下的NTP版本被利用以无限制的访问系统。守护进程不使用root权限的系统(例如BSD)不受此缺陷的影响。

相关

  • 心肌病心肌病变(英语:cardiomyopathy)是一组会影响心肌之疾病的通称。早期的症状可能很轻微,甚至没有症状。有些会是因为心脏衰竭而有呼吸困难、容易疲倦或脚部水肿的情形,可能会有心律
  • 3d2 4s22, 8, 10, 2蒸气压第一:658.8 kJ·mol−1 第二:1309.8 kJ·mol−1 第三:2652.5 kJ·mol−1 (主条目:钛的同位素钛是化学元素,化学符号Ti,原子序数22,是银白色过渡金属,其
  • 塔木德《塔木德》(希伯来文:תלמוד‎,Talmud,为教导或学习之意)是犹太教中认为地位仅次于《塔纳赫》的宗教文献。源于公元前2世纪至公元5世纪间,记录了犹太教的律法、条例和传统。其
  • Oxford University Press牛津大学出版社(Oxford University Press,缩写为OUP)是世界上规模最大的大学出版社,排行第二的是剑桥大学出版社,每年出版的书刊逾4000种。该社是牛津大学其中一个部门 ,掌管该社
  • 销售产品 · 定价 · 分销 服务 · 零售 · 宣传 品牌管理 · 大客户营销 营销道德 · 营销效果 营销调查 · 市场调查 市场划分 · 营销战略 市场优势 · 操
  • 猎户座猎户座计划(Project Orion)是一项旨在直接地以探测器后方一连串的原子弹爆炸来驱动(核脉冲推进)的航天器研究计划。这种飞行器的早期版本被提及到从地面上起飞会带有显著相关的
  • 山珊瑚山珊瑚(学名:Galeola faberi)为兰科山珊瑚属下的一个种。
  • 豫州豫州,是汉族传统中的汉地九州之一,位于黄河至汉水上游之间的地区,领有中原的主要地域,相当今黄河以南的河南省地区。汉武帝元封五年(公元前106年)于豫州地区设置豫州刺史部作为监
  • 刚体在物理学里,理想刚体(rigid body)是一种有限尺寸,可以忽略形变的固体。不论是否感受到外力,在刚体内部,质点与质点之间的距离都不会改变。这种理想模型适用条件是,运动过程比固体中
  • 吉美前列素吉美前列素是前列腺素E1的一种类似物,常用于治疗产科出血,也可与米非司酮一起用于24周内怀孕者堕胎。医学导航:遗传代谢缺陷代谢、k,c/g/r/p/y/i,f/h/s/l/o/e,a/u,n,mk,cgrp/y/