Linux网络时间协议管理——NTP (linux ntp -)

在当今的数字化社会中,准确的时间同步和管理对于系统的运作和数据的安全都至关重要。为了保证计算机系统的时间同步,网络时间协议(NTP)就被开发出来了。在Linux中,可以使用NTP来实现对系统时间的同步管理,本文将介绍如何使用NTP来管理Linux的系统时间。

什么是NTP?

网络时间协议(NTP)是一种用来协调计算机系统时间的协议。该协议使用了一系列的算法和交互过程,以确保系统时间的准确性与同步性。NTP的主要作用是通过获取互联网上的时间服务来依据UTC(协调世界时)作为标准时间,将计算机同步到一个精确的时间。

NTP的特点是,其具有高度的精确性与同步性。它不仅可以处理操作系统时间,还能处理全球性的时间同步和复杂的时钟同步关系。此外,NTP 还支持分布式系统,有助于在分布式计算领域中实现同步。

安装与配置NTP在Linux上

在Linux上安装NTP很简单。一般情况下,您只需在命令行中输入下列命令即可实现安装。

“`shell

sudo apt-get install ntp

“`

安装完成后,NTP所需要的配置文件也将被自动创建,该文件位于/etc/ntp.conf。接下来,您需要编辑该配置文件,以便使NTP同步系统时间。

以下是如何编辑ntp.conf文件的过程:

1. 打开终端窗口。

2. 编辑ntp.conf文件并将文件的末尾添加如下内容:

“`shell

# 这是一个NTP服务器地址样例,请更改

server cn.pool.ntp.org

“`

3. 保存并关闭文件。

配置NTP客户端:设置时间提供者

完成NTP的基本安装和配置后,您需要在Linux中设置时间提供者以实现时间同步。有数百个时间服务提供者可供选择,其中包括NTP服务器和其他时间协议服务。这些时间服务提供者通常被组织在不同的服务器集群中。

要配置Linux中的NTP客户端并将其设置为时间提供者,请按照以下步骤完成操作:

1. 打开终端窗口。

2. 编辑/etc/ntp.conf文件并将文件的末尾添加如下内容:

“`shell

# 这是一个NTP时间服务器样例,请更改

server cn.pool.ntp.org

“`

> **注意:**该代码中的时间服务器地址是位于中国的一个公共时间服务器。请根据您的位置和环境配置相应的服务器地址。

3. 保存并关闭ntp.conf文件。

4. 在终端中,输入以下命令来启动NTP服务:

“`shell

sudo systemctl start ntp

“`

5. 使用以下命令以检查NTP服务是否正在运行:

“`shell

sudo systemctl status ntp

“`

输出信息应该会类似于以下内容:

“`shell

* ntp.service – Network Time Service

Loaded: loaded (/lib/systemd/system/ntp.service; enabled; vendor preset: e

Active: active (running) since Mon 2023-10-21 13:27:16 UTC; 10min ago

Docs: man:ntpd(8)

Mn PID: 1043 (ntpd)

Tasks: 2 (limit: 1574)

Memory: 1.7M

CGroup: /system.slice/ntp.service

`-1043 /usr/in/ntpd -p /var/run/ntpd.pid -g -u 112:118

“`

检查上述输出的最后一行,如果其显示了”Active: active (running)”的信息,这意味着NTP服务已经开始运行了。

配置本地NTP服务器

您也可以配置本地服务器来提供NTP服务,从而可以向其他计算机提供准确的时间同步。在本地服务器上使用NTP有助于在局域网内实现时间同步,提高局域网内的系统协同性和数据的安全性。

要配置本地NTP服务器,请按照以下步骤进行操作:

1. 打开终端窗口。

2. 编辑ntp.conf文件并添加如下内容:

“`shell

# 使用本地网络接口作为源来实现时间同步。(如果您没有公共拨号连接,这是一种选择。)

server 127.127.1.1

fudge 127.127.1.1 stratum 10

“`

3. 保存并关闭ntp.conf文件。

4. 重新启动NTP服务以使更改生效:

“`shell

sudo systemctl restart ntp

“`

NTP是用于计算机系统时间同步的一种协议,其具有高度的同步和准确性。在Linux系统中,可以使用NTP来实现对系统时间的管理和同步。您可以安装配置NTP客户端,以便将其设置为时间提供者。也可以配置本地NTP服务器以实现系统内的时间同步。NTP的配置和使用相对简单,只需遵循上述步骤即可轻松完成。

相关问题拓展阅读:

linux配置ntp时钟源

(一)确认ntp的安装

1)确认是否已安装ntp

【命令】rpm –qa | grep ntp

若只有ntpdate而未见ntp,则需删除原有ntpdate。如:

ntpdate-4.2.6p5-22.el7_0.x86_64

fontpackages-filesystem-1.44-8.el7.noarch

python-ntplib-0.3.2-1.el7.noarch

2)删除已安装ntp

【命令】yum –y remove ntpdate-4.2.6p5-22.el7.x86_64

3)重新安装ntp

【命令】yum –y install ntp

(二)配置ntp服务

1)修改所有节点的/etc/ntp.conf

【命令】vi /etc/ntp.conf

【内容】

restrict 192.168.6.3 nomodify notrap nopeer noquery//当前节点IP地址

restrict 192.168.6.2 mask 255.255.255.0 nomodify notrap //集群所在网段的网关(Gateway)猜启,子网掩码(Genmask)

2)选择一个主节点,修改其/etc/ntp.conf

【命令】vi /etc/ntp.conf

【内容】在server部分添加一下部分,并注释掉server 0 ~ n

server 127.127.1.0

Fudge 127.127.1.0 stratum 10

3)主节点以外,继续修改/etc/ntp.conf

【命令】vi /etc/ntp.conf

【内容】在server部分添加如下语句,将server指向主节点。

server 192.168.6.3

Fudge 192.168.6.3 stratum 10

===修改前===

image

===修改后===

节点1(192.168.6.3):

image

节点2(192.168.6.4):

image

节点3(192.168.6.5):

image

(三)启动ntp服务、查看状态

1)启动ntp服务

【命令】service ntpd start

2)查看ntp服务器有无和上层ntp连通

【命令】ntpstat

image

查看ntp状态时,可能会出现如下所示情况

① unsynchronised time server re-starting polling server every 8 s

image

② unsynchronised polling server every 8 s

image

这种情况属于正常,ntp服务器配置完毕后,需要等待5-10分钟才能与/etc/ntp.conf中配置的标准时间进行同步。

等一段时间之后,再次使用ntpstat命令查看状态,就会变成如下正常结果:

image

3)查看ntp服务器与上层ntp的状态

【命令】ntpq -p

image

remote:本机和上层ntp的ip或主机名,“+”表示优先,“*”表示次优先

refid:参考上一层ntp主机地址

st:stratum阶层

when:多少秒前曾经同步过时间

poll:下次更新在多少秒后

reach:已经向上层ntp服务器要求更新的次数

delay:网络延迟

offset:时间补偿

jitter:系统时间与bios时间差

4)查看ntpd进程的状态

【命令】watch “ntpq -p”

【终止】按 Ctrl+C 停止查看进程。

image

之一列中的字符指示源的质量。星号 ( * ) 表示该源是当前引用。

remote:列出源的 IP 地址或主机名。

when:指出从轮询源开始已过去的时间(秒)。

poll:指出轮询间隔时间。该值会根据本地时钟的精度相应增加穗毕如。

reach:是一个八进制数字,指出源的可存取性。值 377 表示源已应答了前八个连续轮询。

offset:是源时钟与本地时钟的时间差(毫秒)。

(四)设置开机启动

【命令】chkconfig ntpd on

(五)从其数码他博客的一些参考摘录

===/etc/ntp.conf 配置内容===

复制代码

>(javascript:void(0); “复制代码”)

# 1. 先处理权限方面的问题,包括放行上层服务器以及开放局域网用户来源:

restrict default kod nomodify notrap nopeer noquery

复制代码

>(javascript:void(0); “复制代码”)

===restrict选项格式===

restrict mask

“客户端IP” 和 “IP掩码” 指定了对网络中哪些范围的计算机进行控制,如果使用default关键字,则表示对所有的计算机进行控制,参数指定了具体的限制内容,常见的参数如下:

◆ ignore:拒绝连接到NTP服务器

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

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

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

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

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

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

===server选项格式===

server host

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

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

◆ version: 表示发往上层服务器的报文使用的版本号,n默认是3,可以是1或者2。

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

◆ mode: 指定数据报文mode字段的值。

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

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

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

===查看网关方法===

【命令1】route -n

【命令2】ip route show

【命令3】netstat -r

===层次(stratum)===

stratum根据上层server的层次而设定(+1)。

对于提供network time service provider的主机来说,stratum的设定要尽可能准确。

而作为局域网的time service provider,通常将stratum设置为10

image

0层的服务器采用的是原子钟、GPS钟等物理设备,stratum 1与stratum 0 是直接相连的,

往后的stratum与上一层stratum通过网络相连,同一层的server也可以交互。

ntpd对下层client来说是service server,对于上层server来说它是client。

ntpd根据配置文件的参数决定是要为其他服务器提供时钟服务或者是从其他服务器同步时钟。所有的配置都在/etc/ntp.conf文件中。

===注意防火墙屏蔽ntp端口===

ntp服务器默认端口是123,如果防火墙是开启状态,在一些操作可能会出现错误,所以要记住关闭防火墙。ntp采用的时udp协议

sudo firewall-cmd –zone=public –add-port=123/udp –permanent

===同步硬件时钟===

ntp服务,默认只会同步系统时间。

如果想要让ntp同时同步硬件时间,可以设置/etc/sysconfig/ntpd文件,

在/etc/sysconfig/ntpd文件中,添加【SYNC_HWCLOCK=yes】这样,就可以让硬件时间与系统时间一起同步。

允许BIOS与系统时间同步,也可以通过hwclock -w 命令。

===ntpd、ntpdate的区别===

下面是网上关于ntpd与ntpdate区别的相关资料。如下所示所示:

使用之前得弄清楚一个问题,ntpd与ntpdate在更新时间时有什么区别。

ntpd不仅仅是时间同步服务器,它还可以做客户端与标准时间服务器进行同步时间,而且是平滑同步,

并非ntpdate立即同步,在生产环境中慎用ntpdate,也正如此两者不可同时运行。

时钟的跃变,对于某些程序会导致很严重的问题。

许多应用程序依赖连续的时钟——毕竟,这是一项常见的假定,即,取得的时间是线性的,

一些操作,例如数据库事务,通常会地依赖这样的事实:时间不会往回跳跃。

不幸的是,ntpdate调整时间的方式就是我们所说的”跃变“:在获得一个时间之后,ntpdate使用settimeofday(2)设置系统时间,

这有几个非常明显的问题:

【一】这样做不安全。

ntpdate的设置依赖于ntp服务器的安全性,攻击者可以利用一些软件设计上的缺陷,拿下ntp服务器并令与其同步的服务器执行某些消耗性的任务。

由于ntpdate采用的方式是跳变,跟随它的服务器无法知道是否发生了异常(时间不一样的时候,唯一的办法是以服务器为准)。

【二】这样做不精确。

一旦ntp服务器宕机,跟随它的服务器也就会无法同步时间。

与此不同,ntpd不仅能够校准计算机的时间,而且能够校准计算机的时钟。

【三】这样做不够优雅。

由于是跳变,而不是使时间变快或变慢,依赖时序的程序会出错

(例如,如果ntpdate发现你的时间快了,则可能会经历两个相同的时刻,对某些应用而言,这是致命的)。

因而,唯一一个可以令时间发生跳变的点,是计算机刚刚启动,但还没有启动很多服务的那个时候。

其余的时候,理想的做法是使用ntpd来校准时钟,而不是调整计算机时钟上的时间。

NTPD在和时间服务器的同步过程中,会把BIOS计时器的振荡频率偏差——或者说Local Clock的自然漂移(drift)——记录下来。

这样即使网络有问题,本机仍然能维持一个相当精确的走时。

===国内常用NTP服务器地址及IP===

210.72.145.44 (国家授时中心服务器IP地址)

133.100.11.8 日本 福冈大学

time-a.nist.gov 129.6.15.28 NIST, Gaitherurg, Maryland

time-b.nist.gov 129.6.15.29 NIST, Gaitherurg, Maryland

time-a.timefreq.bldrdoc.gov 132.163.4.101 NIST, Boulder, Colorado

time-b.timefreq.bldrdoc.gov 132.163.4.102 NIST, Boulder, Colorado

time-c.timefreq.bldrdoc.gov 132.163.4.103 NIST, Boulder, Colorado

utcnist.colorado.edu 128.138.140.44 University of Colorado, Boulder

time.nist.gov 192.43.244.18 NCAR, Boulder, Colorado

time-nw.nist.gov 131.107.1.10 Microsoft, Redmond, Washington

nist1.symmetricom.com 69.25.96.13 Symmetricom, San Jose, California

nist1-dc.glassey.com 216.200.93.8 Abovenet, Virginia

nist1-ny.glassey.com 208.184.49.9 Abovenet, New York City

nist1-sj.glassey.com 207.126.98.204 Abovenet, San Jose, California

nist1.aol-ca.truetime.com 207.200.81.113 TrueTime, AOL facility, Sunnyvale, California

nist1.aol-va.truetime.com 64.236.96.53 TrueTime, AOL facility, Virginia

————————————————————————————————————

ntp.sjtu.edu.cn 202.120.2.101 (上海交通大学网络中心NTP服务器地址)

s1a.time.edu.cn 北京邮电大学

s1b.time.edu.cn 清华大学

s1c.time.edu.cn 北京大学

s1d.time.edu.cn 东南大学

s1e.time.edu.cn 清华大学

s2a.time.edu.cn 清华大学

s2b.time.edu.cn 清华大学

s2c.time.edu.cn 北京邮电大学

s2d.time.edu.cn 西南地区网络中心

s2e.time.edu.cn 西北地区网络中心

s2f.time.edu.cn 东北地区网络中心

s2g.time.edu.cn 华东南地区网络中心

s2h.time.edu.cn 四川大学网络管理中心

s2j.time.edu.cn 大连理工大学网络中心

s2k.time.edu.cn CERNET桂林主节点

linux修改ntp时钟同步

Linux停止ntp服务即可关闭时间同步。①关清颂闭ntp服务(临时设置重启后自动开启) service ntpd stop②设置永久亩纤关闭答耐郑ntp服务(重启后也是关闭的) chkconfig ntpd off

Linux ntp服务器重启用那条命令

1.linux操作系统,专业袭悄性要求比较高

2.重启动系统用reboot init 6 shutdown -r now

3.重启服务可以用,脊禅耐service restart systemctl restart 表示服务樱春

4.希望可以帮助你,请采纳,谢谢!

reboot

linux ntp -的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux ntp -,Linux网络时间协议管理——NTP,linux配置ntp时钟源,linux修改ntp时钟同步,Linux ntp服务器重启用那条命令的信息别忘了在本站进行查找喔。


数据运维技术 » Linux网络时间协议管理——NTP (linux ntp -)