iputils网络工具时间比对程序clockdiff(检测两台linux主机的时间差)

本文主要是介绍iputils网络工具时间比对程序clockdiff(检测两台linux主机的时间差),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基本原理

在IP报文的首部和ICMP报文的首部都可以放入时间戳数据,clockdiff程序是使用时间戳来测算目的主机和本地主机的系统时间差。


选项:
  • -o :使用IP时间戳选项来测量系统时间差。时间戳只用3个。
    这里写图片描述
  • -o1:使用IP时间戳选项来测量系统时间差。用4个时间戳。如果-o和-o1都没有设置,那么就是用ICMP时间戳来测试系统时间差。
    这里写图片描述

使用示例:
sl@Li:~$ clockdiff 192.168.2.19
.
host=192.168.2.19 rtt=750(187)ms/0ms delta=-41405ms/-41405ms Wed Jul  4 10:08:18 2018sl@Li:~$ clockdiff -o 192.168.2.19
.....
host=192.168.2.19 rtt=237(295)ms/0ms delta=-40110ms/-40110ms Wed Jul  4 10:52:00 2018sl@Li:~$ clockdiff -o1 192.168.2.19
..
host=192.168.2.19 rtt=562(280)ms/0ms delta=-40098ms/-40098ms Wed Jul  4 10:52:26 2018#可以看到时间相差大概40s左右(故意设置了一个较大的时间差),不过在使用clockdiff的时候,需要一点运气,因为很多路由会忽略ICMP或IP时间戳。root@iZuf6a0qg3bqqyctc37f3lZ:~# clockdiff 106.14.135.183
..................................................
host=106.14.135.183 rtt=4(0)ms/4ms delta=2ms/2ms Wed Jul  4 11:02:16 2018#delta = 目标主机减当前主机时间 ,时间单位是毫秒,这个是正常的时间差2ms,后面会谈到精度问题。

程序流程图:

这里写图片描述


clockdiff程序系统时间差测量的实现

设两台主机的系统时间相差detaT,即源主机的系统时间为T的时刻,目的主机的系统时间为T+detaT。

通过ICMP时间戳或者IP选项时间戳,可以获得如下信息:

  • δ 1 \delta_1 δ1:接受时间戳减去发起时间戳。

  • δ 2 \delta_2 δ2:接到回复报文时间减传送时间戳。

时间戳的插入过程如下图所示:
这里写图片描述

由上图可以知道:

  • δ 1 = ( T + d e t a T + R T T / 2 ) – T = R T T / 2 + d e t a T \delta_1 = (T + detaT + RTT/2) – T = RTT/2+detaT δ1=(T+detaT+RTT/2)T=RTT/2+detaT

  • δ 2 = ( T + R T T ) − ( T + d a t a T + R T T / 2 ) = R T T / 2 − d e t a T \delta_2 = (T + RTT) - (T + dataT + RTT/2) =RTT/2-detaT δ2=(T+RTT)(T+dataT+RTT/2)=RTT/2detaT

故此,两个主机之间的系统时间差: d e t a T = ( δ 1 − δ 2 ) / 2 detaT=(\delta_1 - \delta_2) / 2 detaT=(δ1δ2)/2

由于一次测量的 δ 1 \delta_1 δ1 δ 2 \delta_2 δ2可能会由于网络拥塞情况的变化而发生较大偏差,故此在实际的实现中多次测量求较优值。引入了如下几个变量:

  • min1:多次传送中 δ 1 \delta_1 δ1的最小值。

  • min2:多次传送中 δ 2 \delta_2 δ2的最小值。

  • min_rtt:多次传送中 δ 1 + δ 2 \delta_1+\delta_2 δ1+δ2的最小值。

  • PROCESSING_TIME:处理过程中所消耗的时间。

在基于以下的几个基本假设情况下,可以测算系统时间的差值:

  1. RTT中发送到目的主机的时间和返回源主机的时间基本相等都为RTT/2。

  2. 当min1最小时,min1是对RTT/2+detaT的较优预测。同样,当min2最小时,min2是对RTT/2-detaT的较优预测。故此,(min1 - min2)/2是对deltaT的较优预测。这种预测方法的系统时间差预测值存储为变量measure_delta。

  3. 当min_rtt最小时, ( δ 1 − δ 2 ) / 2 (\delta_1 - \delta_2)/2 (δ1δ2)/2也是对deltaT的较优预测。这种预测方法的系统时间差预测值存储为变量measure_delta1。

  4. 各主机从接受到报文到记录接受到报文时间,这两个时刻的时间间隔为可以忽略;即发送和接受报文的处理过程中所消耗的时间可以忽略。实际上PROCESSING_TIME正是用来消除由处理过程的时间造成的对于计算出来的系统时间差别的影响。不过这里PROCESSING_TIME设置为0,认为处理消耗时间可以忽略。

以上的假设决定了clockdiff测算出来的系统时间差别的不准确性。如果一定给这个不准确性确定一个大概的范围,其准确性的最大影响因子是RTT,所以其精确度或者其误差最大不超过RTT。


RTT概念

RTT(Round-Trip Time),往返时延。在计算机网络中它是一个重要的性能指标,表示从发送端发送数据开始,到发送端收到来自接收端的确认(接收端收到数据后便立即发送确认),总共经历的时延。

往返延时(RTT)由三个部分决定:即链路的传播时间、末端系统的处理时间以及路由器的缓存中的排队和处理时间。其中,前面两个部分的值作为一个TCP连接相对固定,路由器的缓存中的排队和处理时间会随着整个网络拥塞程度的变化而变化。所以RTT的变化在一定程度上反映了网络拥塞程度的变化。

RTO: 发送数据包,启动重传定时器,重传定时器到期所花费的时间,称为RTO。其值与RTT有关。


参考文档:
深入理解iputils网络工具-第3篇 clockdiff:时间比对程序

这篇关于iputils网络工具时间比对程序clockdiff(检测两台linux主机的时间差)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/790814

相关文章

Linux线程同步/互斥过程详解

《Linux线程同步/互斥过程详解》文章讲解多线程并发访问导致竞态条件,需通过互斥锁、原子操作和条件变量实现线程安全与同步,分析死锁条件及避免方法,并介绍RAII封装技术提升资源管理效率... 目录01. 资源共享问题1.1 多线程并发访问1.2 临界区与临界资源1.3 锁的引入02. 多线程案例2.1 为

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

Linux如何查看文件权限的命令

《Linux如何查看文件权限的命令》Linux中使用ls-R命令递归查看指定目录及子目录下所有文件和文件夹的权限信息,以列表形式展示权限位、所有者、组等详细内容... 目录linux China编程查看文件权限命令输出结果示例这里是查看tomcat文件夹总结Linux 查看文件权限命令ls -l 文件或文件夹

idea的终端(Terminal)cmd的命令换成linux的命令详解

《idea的终端(Terminal)cmd的命令换成linux的命令详解》本文介绍IDEA配置Git的步骤:安装Git、修改终端设置并重启IDEA,强调顺序,作为个人经验分享,希望提供参考并支持脚本之... 目录一编程、设置前二、前置条件三、android设置四、设置后总结一、php设置前二、前置条件

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

Java获取当前时间String类型和Date类型方式

《Java获取当前时间String类型和Date类型方式》:本文主要介绍Java获取当前时间String类型和Date类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录Java获取当前时间String和Date类型String类型和Date类型输出结果总结Java获取

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

Linux下在线安装启动VNC教程

《Linux下在线安装启动VNC教程》本文指导在CentOS7上在线安装VNC,包含安装、配置密码、启动/停止、清理重启步骤及注意事项,强调需安装VNC桌面以避免黑屏,并解决端口冲突和目录权限问题... 目录描述安装VNC安装 VNC 桌面可能遇到的问题总结描js述linux中的VNC就类似于Window

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin