了解linux网络时间服务器

news2025/1/15 19:48:35
本章主要介绍网络时间服务器。
  • 使用chrony配置时间服务器
  • 配置chrony客户端向服务器同步时间
20.1 时间同步的必要性
些服务对时间要求非常严格,例如,图20-1所示的由三台服务器搭建的ceph集群。
这三台服务器的时间必须保持一致,如果不一致,就会显示警告信息。那么。如何能让这
三台服务器的时间保持一致呢?手动调整时间的方式肯定不行,因为手动调整时间最多只能
精确到分,很难精确到秒。而且即使现在时间调整一致了,过一段时间之后,时间可能又不一
样了。
所以,需要通过设置让这些服务器的时间能够自动同
步,如图20-2所示。

 

这里假设我们有一个时间服务器时间为7:00,设置
server1和 server2向此时间服务器进行时间同步。
假设serverl 当前时间为6;59,它与时间服务器一对
比,“我的时间比时间服务器慢了一分钟”,然后它主板上的晶体芯片就会跳动得快一些,很快
就“追”上了时间服务器的时间。
假设server2当前时间是7:01,它与时间服务器一对比,“我竟然比时间服务器快了一分
钟”,然后它主板上的晶体芯片就会跳动得慢一些,“等着”时间服务器。
下面就开始使用chrony来配置时间服务器。
20.2 配置时间服务器
这里把 server配置成时间服务器,server2作为客户端向server进行时间同步。
在安装系统时,如果已经选择了图形化界面,则默认已经把
chrony这个软件安装上了(如果没有安装,请先看后面的软件
包管理章节,然后自行安装上去)。
使用vim编辑器打开/etc/chrony.conf,只修改我们能用的几
行。
(1)指定所使用的上层时间服务器。
1 把pool 2.rhel.pool.ntp.org iburst修改为pool 127.127.1.0 iburst
pool后面跟的是时间服务器,因为这里把server作为chrony服务器,没有上一层的服务
器,所以上层服务器设置为本地时钟的IP:127.127.1.0。
这里iburst的意思是,如果chrony服务器出问题,客户端会发送一系列的包给chrony服
务器,对服务器进行检测。
(2)指定允许访问的客户端。
修改allow所在行,把注释符#去掉,并把后面的网段改为192.168.248.0/24。
把#allow 192.168.0.0/16修改为allow 192.168.8.0/24
server 配置成时间服务器之后,只允许192.168.248.0/24网段的客户端进行时间同步。如
果要允许所有客户端都能向此时间服务器进行时间同步,可以写成allow 0/0或allow all。
(3)把local stratum 前的注释符#去掉。
1 把#local stratum 10修改为local stratum 10
这行的意思是,即使服务器本身没有和时间服务器保持时间同步,也可以对外提供时间服
务,这行注释要取消。
保存退出,去除空白行和注释行之后,最后修改完成的代码如下,加粗字是修改的内容。
[root@pp ~]# egrep -v "^#|^$" /etc/chrony.conf 
pool 127.127.1.0 iburst
driftfile /var/lib/chrony/drift
makestep 1.0 3
rtcsync
allow 192.168.248.0/16
local stratum 10
keyfile /etc/chrony.keys
leapsectz right/UTC
logdir /var/log/chrony
[root@pp ~]# 
然后重启chronyd这个服务(注意,这里是chronyd而不是chrony),并设置开机自动启动,
命令如下。
[root@pp ~]# systemctl restart chronyd
[root@pp ~]# systemctl enable chronyd
Created symlink /etc/systemd/system/multi-user.target.wants/chronyd.service → /usr/lib/systemd/system/chronyd.service.
[root@pp ~]# 
chrony用的是UDP的123和323,命令如下。
[root@pp ~]# netstat -nutlp | grep chronyd
udp        0      0 0.0.0.0:123             0.0.0.0:*                           4037/chronyd        
udp        0      0 127.0.0.1:323           0.0.0.0:*                           4037/chronyd        
udp6       0      0 ::1:323                 :::*                                4037/chronyd        
[root@pp ~]# 
在防火墙中把这两个端口开放,命令如下。
[root@pp ~]# firewall-cmd --add-port=123/udp --permanent
success
[root@pp ~]# firewall-cmd --add-port=323/udp --permanent
success
[root@pp ~]# firewall-cmd --reload 
success
[root@pp ~]# 
这里加上 --permanent选项的目的是让其永久生效,然后通过reload重新加载防火墙规则,
让其也立即生效。防火墙的具体设置后面有专门章节讲解。
至此,用chrony搭建的时间服务器完成。
20.3 配置chrony客户端
把server2配置成时间服务器的客户端,也就是chrony客户端。
在server2(IP地址为192.168.248.23)上用vim编辑器修改/etc/chrony.conf,修改下面的
几行。
(1)修改pool那行,指定要从哪台时间服务器同步时间。
1 由原来的pool 2.rhel.pool.ntp.org iburst改为pool 192.168.248.45 iburst
这里指定时间服务器为192.168.26.101,即向192.168.26.101进行时间同步。
(2)修改makestep那行,格式如下。
1 makestep 阈值 limit
客户端向服务器同步时间有两种方式:step和 slew。
step:跳跃着更新时间,如时间由1点直接跳到7点。
slew:平滑着移动时间,晶体芯片跳动得快一些,就好比秒针的转速“快进”了一样。
如果客户端和服务器的时间相差较多,则通过step的方式更新时间;如果客户端和服务器
的时间相差不多,则通过slew的方式更新时间。那么,时间相差多或不多的标准是什么呢?
就要看时间差是否超过makestep后面的住值了。
举一个例子,makestep 10 3的意思是,如果客户端和服务器的时间相差10秒以上,就认
为客户端和服务器的时间相差较多,则前三次通过step 的方式更新时间。客户端通过这种方 式会更新得很快,有些应用程序因为时间的突然跳动会带来问题。
如果客户端和服务器的时间相差10秒以内,就认为二者时间相差不多,则通过slew的方
式更新时间。这种方式更新的速度会比较慢,但比较平稳。
1 把原来的makestep 10 3改成makestep 200 3
如果客户端和服务器的时间相差200秒以上,就认为二者时间相差较多,则通过step的方
式更新时间。
保存退出并重启 chronyd服务,命令如下。
[root@up ~]# systemctl restart chronyd.service 
[root@up ~]# systemctl enable chronyd.service 
[root@up ~]# 
为了更细致地看到两台机器的时间差,先配置ssh使得server2可以无密码登录到server。
先生成密钥对,命令如下。
[root@up ~]# ssh-keygen -N "" -f /root/.ssh/id_rsa
Generating public/private rsa key pair.
Created directory '/root/.ssh'.
配置到server的密钥登录,命令如下。
[root@up ~]# ssh-copy-id 192.168.248.45
给server2上通过date命令设置时间,使得server2和server的时间相差200秒,命令如下。
[root@up ~]# date -s "2023-12-07 12:30:00" ; hwclock -w
2023年 12月 07日 星期四 12:30:00 CST
[root@up ~]# 
然后同时显示两台机器的时间,命令如下。
[root@up ~]# date ; ssh 192.168.248.45 date
2023年 12月 07日 星期四 12:30:34 CST
2023年 12月 07日 星期四 20:15:43 CST
[root@up ~]# 
然后重启server2的chronyd服务,等待几秒之后再次查看。
[root@up ~]# date ; ssh 192.168.248.45 date
2023年 12月 07日 星期四 20:17:06 CST
2023年 12月 07日 星期四 20:17:06 CST
[root@up ~]# 
可以看到,时间很快就同步了,因为这是通过step的方式同步的。
再次修改时间,命令如下。
[root@up ~]# date -s "2023-12-07 20:18:00" ; hwclock -w
2023年 12月 07日 星期四 20:18:00 CST
[root@up ~]# date ; ssh 192.168.248.45 date
2023年 12月 07日 星期四 20:18:02 CST
2023年 12月 07日 星期四 20:18:18 CST
[root@up ~]# 
两台机器的时间相差1分40秒,即100秒,这个值低于200秒,即在makestep的阙值范围
之内,此时客户端向服务器进行时间同步时只能通过slew的方式同步。
此时重启 chronyd服务,也不会保持时间同步,命令如下。
[root@up ~]# systemctl restart chronyd.service 
[root@up ~]# date ; ssh 192.168.248.45 date
2023年 12月 07日 星期四 20:19:04 CST
2023年 12月 07日 星期四 20:19:19 CST
[root@up ~]# 
可以看到,并没有同步,因为slew同步的速度比较慢。
此时如果通过执行chronyc makestep命令手动step同步,则会立即同步时间,命令如
下。
[root@up ~]# chronyc makestep 
200 OK
[root@up ~]# date ; ssh 192.168.248.45 date
2023年 12月 07日 星期四 20:20:12 CST
2023年 12月 07日 星期四 20:20:13 CST
[root@up ~]# 
这样就可以看到立即同步成功了。
通过chronye -n sources -v查看现在的同步状况
[root@up ~]# chronyc -n sources -v

  .-- Source mode  '^' = server, '=' = peer, '#' = local clock.
 / .- Source state '*' = current best, '+' = combined, '-' = not combined,
| /             'x' = may be in error, '~' = too variable, '?' = unusable.
||                                                 .- xxxx [ yyyy ] +/- zzzz
||      Reachability register (octal) -.           |  xxxx = adjusted offset,
||      Log2(Polling interval) --.      |          |  yyyy = measured offset,
||                                \     |          |  zzzz = estimated error.
||                                 |    |           \
MS Name/IP address         Stratum Poll Reach LastRx Last sample               
===============================================================================
^* 192.168.248.45               10   6    37    32    +11ns[+6520ns] +/-  126us
[root@up ~]# 
可以看到,server2是向192.168.248.45进行时间同步的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1291498.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

10 单词接龙

题目描述 单词接龙的规则是: 可用于接龙的单词首字母必须要前一个单词的尾字母相同; 当存在多个首字母相同的单词时,取长度最长的单词,如果长度也相等,则取字典序最小的单词;已经参与接龙的单词不能重复使用。 现给定一组全部由小写字母组成…

【开发技能】-解决visio交叉线(跨线)交叉点弯曲问题

问题 平时工作中使用visio作图时,经常会遇到交叉线在相交时会形成一个弯曲弓形,这十分影响视图效果。可以采用下面的方法消除弓形。 方法 第一步:菜单栏--设计---连接线 第二步:选中这条交叉线---点击显示跨线 最终问题得到解决…

C#图像处理OpenCV开发指南(CVStar,09)——边缘识别之Scharr算法的实例代码

1 边缘识别之Scharr算法 算法文章很多,不再论述。 1.1 函数原型 void Cv2.Scharr(src,dst,ddepth,dx,dy,scale,delta,borderType) 1.2 参数说明 src 代表原始图像。dst 代表目标图像。ddepth 代表输出图像的深度。CV_16Sdx 代表x方向上的求导阶数…

23款奔驰E350eL升级小柏林音响 13个扬声器 590w

小柏林之声音响是13个喇叭1个功放,功率是590W,对应普通音响来说,已经是上等了。像著名的哈曼卡顿音响,还是丹拿音响,或者是BOSE音响,论地位,论音质柏林之声也是名列前茅。 升级小柏林音响&#…

java多人聊天

服务端 package 多人聊天;import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import java.io.OutputStream; import java.io.PrintStream; import java.net.ServerSocket; import java.net.Socket; import java.util.ArrayList;…

qt 5.15.2 主窗体菜单工具栏树控件功能

qt 5.15.2 主窗体菜单工具栏树控件功能 显示主窗体效果&#xff1a; mainwindow.h文件内容&#xff1a; #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow> #include <QFileDialog> #include <QString> #include <QMessageBox>#inc…

深入理解Sentinel系列-2.Sentinel原理及核心源码分析

&#x1f44f;作者简介&#xff1a;大家好&#xff0c;我是爱吃芝士的土豆倪&#xff0c;24届校招生Java选手&#xff0c;很高兴认识大家&#x1f4d5;系列专栏&#xff1a;Spring源码、JUC源码、Kafka原理、分布式技术原理&#x1f525;如果感觉博主的文章还不错的话&#xff…

CAP理论详解

引言 随着分布式系统在现代应用中的广泛应用&#xff0c;工程师们不得不面对诸如数据一致性、可用性和分区容错性等问题。CAP定理作为分布式系统设计的基石之一&#xff0c;为我们提供了在这些问题之间做出权衡的理论依据。本文将深入探讨CAP定理的技术细节、先进性&#xff0…

深度学习记录--广播(Broadcasting)

什么是广播&#xff1f; 广播(Broadcasting)&#xff0c;在python中是一种矩阵初等运算的手段&#xff0c;用于将一个常数扩展成一个矩阵&#xff0c;使得运算可行 广播的作用 比如&#xff1a; 一个1*n的矩阵要和常数b相加&#xff0c;广播使得常数b扩展成一个1*n的矩阵 …

mysql的几种索引

mysql索引的介绍可以mysql官网的词汇表中搜索&#xff1a; https://dev.mysql.com/doc/refman/8.0/en/glossary.html mysql可以在表的一列、或者多列上创建索引&#xff0c;索引的类型可以选择&#xff0c;如下&#xff1a; 普通索引&#xff08;KEY&#xff09; 普通索引可…

SQLserver截取字符串

当我们存的数据是json的时候可以全部取出在模糊查询但是有多个重复数据的时候就没办法准确的模糊出来这个时候我们就需要用的字符串截取 --创建函数create FUNCTION [dbo].[Fmax] (str varchar(50),start VARCHAR(50),length VARCHAR(50)) RETURNS varchar(max) AS BEGINDEC…

McBSP接口概念和使用

copy McBSP包括一个数据通道和一个控制通道&#xff0c;通过7个引脚与外部设备连接。数据发送引脚DX负责数据的发送&#xff0c;数据接收引脚DR负责数据的接收&#xff0c;发送时钟引脚CLKX&#xff0c;接收时钟引脚CLKR&#xff0c;发送帧同步引脚FSX和接收帧同步引脚FSR提供…

Python语言基础知识(一)

文章目录 1、Python内置对象介绍2、标识符与变量3、数据类型—数字4、数据类型—字符串与字节串5、数据类型—列表、元组、字典、集合6、运算符和表达式7、运算符和表达式—算术运算符8、运算符和表达式—关系运算符9.1、运算符和表达式— 成员测试运算符in9.2、运算符和表达式…

外贸平台自建站的教程?做海洋建站的好处?

外贸平台自建站怎么做&#xff1f;搭建网站的具体流程有哪些&#xff1f; 作为外贸从业者&#xff0c;借助互联网平台自建站点已经成为推广业务、拓展市场的一种重要手段。海洋建站将为您提供一份详尽的外贸平台自建站的教程&#xff0c;助您在网络空间中展现您的企业魅力。 …

RocketMQ-RocketMQ⾼性能核⼼原理分析

一、源码环境搭建 1、主要功能模块 ​ RocketMQ的官方Git仓库地址&#xff1a;https://github.com/apache/rocketmq 可以用git把项目clone下来或者直接下载代码包。 ​ 也可以到RocketMQ的官方网站上下载指定版本的源码&#xff1a; http://rocketmq.apache.org/dowloading/…

新能源车交直流充电解释

交流充电&#xff1a; 国家电网输出的电都是交流电&#xff0c;如下图所示&#xff0c;具有正弦切换规律的 而电动车的电池只能接受直流电&#xff0c;因此需要首先把交流电转换成直流电才能充进汽车电池&#xff0c;这就需要到了转换器OBC&#xff08;on-board Charger&#…

PPOCRv3检测模型和识别模型的训练和推理

PPOCRv3检测模型和识别模型的训练和推理 文章目录 PPOCRv3检测模型和识别模型的训练和推理前言一、环境安装1&#xff0c;官方推荐环境&#xff1a;2&#xff0c;本机GPU环境 二、Conda虚拟环境1.Win10安装Anaconda32.使用conda创建虚拟环境 三、安装PPOCR环境1&#xff0c;安装…

基于ssm人事管理信息系统论文

摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本人事管理信息系统就是在这样的大环境下诞生&#xff0c;其可以帮助管理者在短时间内处理完毕庞大的数据信息…

跨境电商危机公关:应对负面舆情的策略优化

随着跨境电商的快速发展&#xff0c;企业在全球市场中面临的竞争与挑战也日益复杂。在这个数字时代&#xff0c;负面舆情一旦爆发&#xff0c;可能对企业形象和经营造成深远影响。 因此&#xff0c;跨境电商企业需要建立有效的危机公关策略&#xff0c;以迅速、果断、有效地应…

Vue + Element 实现按钮指定间隔时间点击

1、业务需求 需要加一个按钮&#xff0c;调用第三方API&#xff0c;按钮十分钟之内只能点击一次&#xff0c;刷新页面也只能点击一次 2、思路 加一个本地缓存的时间戳&#xff0c;通过时间戳计算指定时间内不能点击按钮 3、实现 1&#xff09;vue页面 <template>&l…