zoukankan      html  css  js  c++  java
  • debian 安装使用NTP

    编程之路刚刚开始,错误难免,希望大家能够指出。

    领导要求,要4台机器时钟同步,上网查了查,主要看了看ptp和ntp,感觉ntp就够用,索性就直接上手ntp了。

    以下内容纯属最基础的内容,只适合第一次接触ntp并且需求简单的朋友。

    就我当前项目来介绍下ntp:多台计算机因为某些原因对时间的同步性比较重视,所以需要不间断的去同步各个计算机的时间,而ntp就是使网络中的各个计算机时间同步的一种协议,其精度在局域网内可达0.1ms,在互联网上绝大多数的地方其精度可以达到1-50ms。

    第一步:安装ntp

    aptitude install npt (此处用apt-get 也可以,但建议使用aptitude,就我目前知道的是aptitude安装后的软件卸载时能够将其的依赖包也卸载掉,而apt-get的卸载无法办到,两者建议不要混用。)

    第二步:查看安装是否成功

    service --status-all

    /etc/ntp.conf是ntp的配置文件,第一次接触最好在编辑之前先备份,你懂得。

    第三步:了解/etc/ntp.conf设置

      简单的来说,该文件其实就两关键词restrict和server,前者是用来做限制的,后者是用来连接上层服务器(ntp一共16层,第16层无法同步)

      restrict [ 客户端IP ]  mask  [ IP掩码 ]  [参数]

        “客户端IP” 和 “IP掩码” 如果使用default关键字,表示对所有的计算机进行控制,常见的参数如下:

        ignore:拒绝连接到NTP服务器

        nomodiy: 客户端不能更改服务端的时间参数,但是客户端可以通过服务端进行网络校时。

        noquery: 不提供客户端的时间查询

        notrap: 不提供trap远程登录功能,trap服务是一种远程时间日志服务。

        notrust: 客户端除非通过认证,否则该客户端来源将被视为不信任子网 。

        nopeer: 提供时间服务,但不作为对等体。

        kod: 向不安全的访问者发送Kiss-Of-Death报文。

      server [上层服务器的IP或域名]   [参数]

    其中host是上层NTP服务器的IP地址或域名,随后所跟的参数解释如下所示:

        key: 表示所有发往服务器的报文包含有秘钥加密的认证信息,n是32位的整数,表示秘钥号。

        prefer: 如果有多个server选项,具有该参数的服务器有限使用。

        minpoll: 指定与查询该服务器的最小时间间隔为2的n次方秒,n默认为6,范围为4-14。

        maxpoll:  指定与查询该服务器的最大时间间隔为2的n次方秒,n默认为10,范围为4-14。

        iburst: 当初始同步请求时,采用突发方式接连发送8个报文,时间间隔为2秒。

    第四步:编辑/etc/ntp.conf

      编辑之前一定要知道ntp的每层设备都是服务器,下面说的服务端和客户端都是相对而言的。

      先上服务端

      

      

      客服端

      

    第五步:运行ntp

      服务端和客户端的配置文件在编辑完保存后就可以重新启动ntp了:

      /etc/init.d/ntp restart

       重启时间可能会比较长,大概在5分钟左右。

      可以通过ntpq -p来查看所有作为时钟源校正过本地NTP服务器时钟的上层NTP服务器

      

      各个选项的解释:

        remote: 远程NTP服务器的IP地址或域名,带 “*” 的表示本地NTP服务器与该服务器同步。

        refid: 远程NTP服务器的上层服务器的IP地址或域名。

        st: 远程NTP服务器所在的层数。

        t: 本地NTP服务器与远程NTP服务器的通信方式,u: 单播; b: 广播; l: 本地。

        when: 上一次校正时间与现在时间的差值。

        poll: 本地NTP服务器查询远程NTP服务器的时间间隔。

        reach: 是一种衡量前8次查询是否成功的位掩码值,377表示都成功,0表示不成功。

        delay: 网络延时,单位是10的-6次方秒。

        offset: 本地NTP服务器与远程NTP服务器的时间偏移。

        jitter: 查询偏差的分布值,用于表示远程NTP服务器的网络延时是否稳定,单位为10的-6次方秒

      还可以通过ntptrace查看本地NTP服务器的在第几层。

      

      

      最后提一下ntpd和ntpdate(教程为ntpd):

       ntpd在实际同步时间时是一点点的校准过来时间的,最终把时间慢慢的校正对。而ntpdate不会考虑其他程序是否会阵痛,直接调整时间。简单的说就是ntpd是校准时间,ntpdate是调整时间。
       不建议大家使用ntpdate,原因摘抄其他前辈的笔记:

      第一,这样做不安全。ntpdate的设置依赖于ntp服务器的安全性,攻击者可以利用一些软件设计上的缺陷,拿下ntp服务器并令与其同步的服务器执行某些消耗性的任务。由于ntpdate采用的方式是跳变,跟随它的服务器无法知道是否发生了异常(时间不一样的时候,唯一的办法是以服务器为准)。
      第二,这样做不精确。一旦ntp服务器宕机,跟随它的服务器也就会无法同步时间。与此不同,ntpd不仅能够校准计算机的时间,而且能够校准计算机的时钟。
      第三,这样做不够优雅。由于是跳变,而不是使时间变快或变慢,依赖时序的程序会出错(例如,如果ntpdate发现你的时间快了,则可能会经历两个相同的时刻,对某些应用而言,这是致命的)。

  • 相关阅读:
    小白开学Asp.Net Core 《一》
    小白开学Asp.Net Core 开篇
    分享一个.NET平台开源免费跨平台的大数据分析框架.NET for Apache Spark
    微信支付退款中发现的一个问题
    发布mvc遇到的HTTP错误 403.14-Forbidden解决办法
    English--元音
    开发工具--浅谈Git
    开发工具--搭建python环境
    开发工具--PyCharm
    English--介词省略句型与总结
  • 原文地址:https://www.cnblogs.com/jiangyibo/p/8626196.html
Copyright © 2011-2022 走看看