Linux---网络时间服务器

news2025/1/15 13:14:28

本章主要介绍网络时间服务器。

  • 使用chrony配置时间服务器
  • 配置chrony客户端向服务器同步时间

     时间同步的必要性 

一些服务对时间要求非常严格,例如,下图所示的由三台服务器搭建的ceph集群。 

   这三台服务器的时间必须保持一致,如果不一致,就会显示警告信息。那么。如何能让这三台服务器的时间保持一致呢?手动调整时间的方式肯定不行,因为手动调整时间最多只能精确到分,很难精确到秒。而且即使现在时间调整一致了,过一段时间之后,时间可能又不一 样了。 

所以,需要通过设置让这些服务器的时间能够自动同 步,如下图所示。 

   这里假设我们有一个时间服务器时间为7:00,设置 server1和 server2向此时间服务器进行时间同步。 假设server1当前时间为6;59,它与时间服务器一对比,“我的时间比时间服务器慢了一分钟”,然后它主板上的晶体芯片就会跳动得快一些,很快 就“追”上了时间服务器的时间。 

  假设server2当前时间是7:01,它与时间服务器一对比,“我竟然比时间服务器快了一分 钟”,然后它主板上的晶体芯片就会跳动得慢一些,“等着”时间服务器。

下面就开始使用chrony来配置时间服务器。 


配置时间服务器 

  实验拓扑图如下图所示。 这里把rhel03配置成时间服务器,rhel04作为客户端向rhel03进行时间同步。 

 

  在安装系统时,如果已经选择了图形化界面,则默认已经把 chrony这个软件安装上了(如果没有安装,请先看后面的软件包管理章节,然后自行安装上去)。 

使用vim编辑器打开/etc/chrony.conf,只修改我们能用的几行。 

(1)指定所使用的上层时间服务器。 把pool 2.rhel.pool.ntp.org iburst修改为pool 127.127.1.0 iburst

pool 127.127.1.0 iburst

  pool后面跟的是时间服务器,因为这里把rhel03作为chrony服务器,没有上一层的服务器,所以上层服务器设置为本地时钟的IP:127.127.1.0。 

  这里iburst的意思是,如果chrony服务器出问题,客户端会发送一系列的包给chrony服务器,对服务器进行检测。 

(2)指定允许访问的客户端。 修改allow所在行,把注释符#去掉,并把后面的网段改为192.168.8.0/24。

allow 192.168.23.0/24

  rhel03配置成时间服务器之后,只允许192.168.23.0/24网段的客户端进行时间同步。如果要允许所有客户端都能向此时间服务器进行时间同步,可以写成allow 0/0或allow all。 

(3)把local stratum 前的注释符#去掉。 

local stratum 10

  这行的意思是,即使服务器本身没有和时间服务器保持时间同步,也可以对外提供时间服务,这行注释要取消。 

保存退出,去除空白行和注释行之后,最后修改完成的代码如下,加粗字是修改的内容。 

[root@rhel03 ~]# egrep -v "^#|^$" /etc/chrony.conf 
pool 127.127.1.0 iburst
driftfile /var/lib/chrony/drift
makestep 1.0 3
rtcsync
allow 192.168.23.0/24
local stratum 10
keyfile /etc/chrony.keys
leapsectz right/UTC
logdir /var/log/chrony
[root@rhel03 ~]#

  然后重启chronyd这个服务(注意,这里是chronyd而不是chrony),并设置开机自动启动, 命令如下。 

[root@rhel03 ~]# systemctl restart chronyd
[root@rhel03 ~]# systemctl enable chronyd
Created symlink /etc/systemd/system/multi-user.target.wants/chronyd.service → /usr/lib/systemd/system/chronyd.service.
[root@rhel03 ~]#

chrony用的是UDP的123和323,命令如下。 

[root@rhel03 ~]# netstat -nutlp | grep chrony
udp        0      0 0.0.0.0:123             0.0.0.0:*                           2439/chronyd        
udp        0      0 127.0.0.1:323           0.0.0.0:*                           2439/chronyd        
udp6       0      0 ::1:323                 :::*                                2439/chronyd 

在防火墙中把这两个端口开放,命令如下。 

[root@rhel03 ~]# firewall-cmd --add-port=123/udp --permanent 
success
[root@rhel03 ~]# firewall-cmd --add-port=323/udp --permanent 
success
[root@rhel03 ~]# firewall-cmd --reload 
success
[root@rhel03 ~]# firewall-cmd --list-port
123/udp 323/udp
[root@rhel03 ~]# 

  这里加上 --permanent选项的目的是让其永久生效,然后通过reload重新加载防火墙规则, 让其也立即生效。防火墙的具体设置后面有专门章节讲解。 

至此,用chrony搭建的时间服务器完成。


配置chrony客户端 

把rhel04配置成时间服务器的客户端,也就是chrony客户端。 

在rhel04(IP地址为192.168.23.34)上用vim编辑器修改/etc/chrony.conf,修改下面的几行。 

(1)修改pool那行,指定要从哪台时间服务器同步时间。 

pool 192.168.23.33 iburst

这里指定时间服务器为192.168.23.33,即向192.168.23.33进行时间同步。 

(2)修改makestep那行,格式如下。 

  • makestep 阈值 limit 

客户端向服务器同步时间有两种方式:step和 slew。 

step:跳跃着更新时间,如时间由1点直接跳到7点。 

slew:平滑着移动时间,晶体芯片跳动得快一些,就好比秒针的转速“快进”了一样。 

  如果客户端和服务器的时间相差较多,则通过step的方式更新时间;如果客户端和服务器 的时间相差不多,则通过slew的方式更新时间。那么,时间相差多或不多的标准是什么呢? 就要看时间差是否超过makestep后面的住值了。 

  举一个例子makestep 10 3的意思是,如果客户端和服务器的时间相差10秒以上,就认为客户端和服务器的时间相差较多,则前三次通过step 的方式更新时间。客户端通过这种方式会更新得很快,有些应用程序因为时间的突然跳动会带来问题。 

  如果客户端和服务器的时间相差10秒以内,就认为二者时间相差不多,则通过slew的方式更新时间。这种方式更新的速度会比较慢,但比较平稳。 

把原来的makestep 10 3改成makestep 200 3

makestep 200 3

  如果客户端和服务器的时间相差200秒以上,就认为二者时间相差较多,则通过step的方 式更新时间。 

保存退出并重启 chronyd服务,并设置开机自启,命令如下。 

[root@rhel04 ~]# systemctl restart chronyd.service 
[root@rhel04 ~]# systemctl enable chronyd.service 
Created symlink /etc/systemd/system/multi-user.target.wants/chronyd.service → /usr/lib/systemd/system/chronyd.service.
[root@rhel04 ~]#

  为了更细致地看到两台机器的时间差,先配置ssh使得rhel04可以无密码登录到rhel03。 先生成密钥对,命令如下。 

[root@rhel04 ~]# ssh-keygen -N "" -f /root/.ssh/id_rsa
Generating public/private rsa key pair.
Your identification has been saved in /root/.ssh/id_rsa.
Your public key has been saved in /root/.ssh/id_rsa.pub.
The key fingerprint is:
SHA256:1Sn+0/zkXgLMObB7M/UK8VlsXmo/IzkA5xsiJPFxi48 root@rhel04
The key's randomart image is:
+---[RSA 3072]----+
|                 |
|     . . . . .   |
|      o + = o    |
|     . + = B . . |
|      o S * B . =|
|       E o * O B.|
|        . o @ X =|
|           o X X.|
|              +.B|
+----[SHA256]-----+
[root@rhel04 ~]# 

配置到rhel03的密钥登录,命令如下。 

[root@rhel04 ~]# ssh-copy-id 192.168.23.33
/usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub"
/usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed
/usr/bin/ssh-copy-id: INFO: 1 key(s) remain to be installed -- if you are prompted now it is to install the new keys
root@192.168.23.33's password: 

Number of key(s) added: 1

Now try logging into the machine, with:   "ssh '192.168.23.33'"
and check to make sure that only the key(s) you wanted were added.

[root@rhel04 ~]#

 给rhel04上通过date命令设置时间,使得rhel04和rhel03的时间相差200秒,命令如下

[root@rhel04 ~]# date -s  "2023-12-08 11:28:00" ; hwclock -w
2023年 12月 08日 星期五 11:28:00 CST

然后同时显示两台机器的时间,命令如下。 

[root@rhel04 ~]# date ; ssh 192.168.23.33 date
2023年 12月 08日 星期五 11:28:41 CST
2023年 12月 08日 星期五 11:26:43 CST
[root@rhel04 ~]# 

 可以看到,时间相差了约118秒

然后重启rhel04的chronyd服务,等待几秒之后再次查看。 

[root@rhel04 ~]# systemctl restart chronyd.service 
[root@rhel04 ~]# date ; ssh 192.168.23.33 date
2023年 12月 08日 星期五 11:30:33 CST
2023年 12月 08日 星期五 11:28:39 CST

  两台机器的时间相差118秒,这个值低于200秒,即在makestep的阙值范围之内,此时客户端向服务器进行时间同步时只能通过slew的方式同步。

可以看到,并没有同步,因为slew同步的速度比较慢。 

 此时如果通过执行chronyc makestep命令手动step同步,则会立即同步时间,命令如 下。

[root@rhel04 ~]# chronyc makestep 
200 OK
[root@rhel04 ~]# date ; ssh 192.168.23.33 date
2023年 12月 08日 星期五 11:31:02 CST
2023年 12月 08日 星期五 11:31:03 CST
[root@rhel04 ~]# 

这样就可以看到立即同步成功了。 

 再次修改时间,命令如下。

[root@rhel04 ~]# date -s  "2023-12-08 11:50:00" ; hwclock -w
2023年 12月 08日 星期五 11:50:00 CST
[root@rhel04 ~]# date ; ssh 192.168.23.33 date
2023年 12月 08日 星期五 11:50:04 CST
2023年 12月 08日 星期五 11:31:52 CST
[root@rhel04 ~]#

可以看到,时间相差了约20分钟,即1200秒。 

然后重启rhel04的chronyd服务,等待几秒之后再次查看。

[root@rhel04 ~]# systemctl restart chronyd.service 
[root@rhel04 ~]# date ; ssh 192.168.23.33 date
2023年 12月 08日 星期五 11:32:48 CST
2023年 12月 08日 星期五 11:32:48 CST
[root@rhel04 ~]#

通过chronye -n sources -v查看现在的同步状况,如下所示。

[root@rhel04 ~]# 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.23.33                10   6    37    15    +25us[ -226us] +/-  668us
[root@rhel04 ~]# 

可以看到,rhel04是向192.168.23.33进行时间同步的。 

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

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

相关文章

dockerfile简单实践部署(jenkins,wordpress)

实现部署jenkins的流程 配置java环境,导入jenkins包,运行命令 java -jar jenkins包,这里为了减少进入jenkins的web端安装插件,将插件提前部署到容器内。 制作dockerfile 创建镜像所在的文件夹和Dockerfile文件 mkdir /test cd …

谷歌正式发布最强 AI 模型 Gemini

2023年12月6日,谷歌公司宣布推出其被认为是规模最大、功能最强大的人工智能模型 Gemini。 Gemini将分为三个不同的套件:Gemini Ultra、Gemini Pro和Gemini Nano。 Gemini Ultra被认为具备最强大的能力,Gemini Pro则可扩展至多任务&#x…

Flask template+Vue +项目中include引入其他模版(其他模版也会用到vue)的使用探索

项目背景是:团队的历史项目,是flask tmeplate写的前段页面。然后我在一个页面A.html中引入了vue文件,使用了vueelement_ui技术。现在想在此A页面中插入另外一个页面B.html的内容(试图tab分开),因为入口只有…

matplot绘图时图像太大报错但能保存

matplot绘图时,图像太大,可能在jupyter里面报错,但是图像可以保存。 报错:Image size of 12237479x675 pixels is too large. It must be less than 2^16 in each direction. 在这里插入图片描述

数字图像处理(实践篇)十九 漫水填充

目录 一 漫水填充算法--FloodFill 二 涉及的函数 三 实践 一 漫水填充算法--FloodFill FloodFill漫水填充算法就是选中与种子点相连接的区域,利用指定颜色进行区域颜色填充。可以通过设置连通方式或像素的范围控制填充的效果。通常是用来标记或者分离图像的一部…

(c语言进阶)联合

一.定义 联合体与结构体极其相似&#xff0c;只不过联合体的所有成员是共用同一块内存的。 二.联合体大小的计算 联合体共用内存的大小为联合体成员大小的最大值来定 #include<stdio.h> union Un {int a;char c; }; int main() {union Un u;printf("%zu",s…

Leetcode—213.打家劫舍II【中等】

2023每日刷题&#xff08;五十二&#xff09; Leetcode—213.打家劫舍II 算法思路 实现代码 class Solution { public:// 左闭右开int rob1(vector<int>& nums, int start, int end) {int n nums.size();int f0 0, f1 0, new_f 0;for(int i start; i < end…

新生儿出生缺陷筛查的关键注意事项

引言&#xff1a; 新生儿的出生缺陷是一个复杂而广泛的问题&#xff0c;及早的筛查和诊断对于预防和管理这些缺陷至关重要。出生缺陷可能涉及各个系统&#xff0c;包括心脏、神经、遗传等&#xff0c;因此及时而全面的筛查对新生儿的健康至关重要。本文将深入探讨新生儿出生缺…

AMC8竞赛第一题很简单?来看看历年的真题体会一下(含详细解析)

作为具有全球影响力的&#xff0c;面向中小学生的数学竞赛&#xff0c;AMC8在中国的知名度和参与人数也越来越多。 和国内的各种数学比赛相比&#xff0c;AMC8有一个很有意思的地方&#xff1a;全部是单项选择题&#xff0c;没有其他题型。所以不用担心做不完&#xff0c;毕竟…

利用proteus实现串口助手和arduino Mega 2560的串口通信

本例用到的proteus版本为8.13&#xff0c;ardunio IDE版本为2.2.1&#xff0c;虚拟串口vspd版本为7.2&#xff0c;串口助手SSCOM V5.13.1。软件的下载安装有很多教程&#xff0c;大家可以自行搜索&#xff0c;本文只介绍如何利用这4种软件在proteus中实现arduino Mega 2560的串…

P3613 【深基15.例2】寄包柜(map)

本题我之前尝试用过vector&#xff0c;但是内存会超&#xff0c;所以用了map就过了 注意二维map的写法 map<int,map<int,int>> mp map<a,map<b,c>> mp; 会创立一个mp[b][c] a;的数组&#xff0c;其中a&#xff0c;b&#xff0c;c为数据类型 #inc…

Java网络编程 *TCP与UDP协议*

网络编程 什么是计算机网络? 把分布在不同地理区域的具有独立功能的计算机,通过通信设备与线路连接起来&#xff0c;由功能完善的软件实现资源共享和信息传递的系统 简单来说就是把不同地区的计算机通过设备连接起来,实现不同地区之前的数据传输 网络编程是干什么的? 网络…

【PyTorch】 暂退法(dropout)

文章目录 1. 理论介绍2. 实例解析2.1. 实例描述2.2. 代码实现2.2.1. 主要代码2.2.2. 完整代码2.2.3. 输出结果 1. 理论介绍 线性模型泛化的可靠性是有代价的&#xff0c;因为线性模型没有考虑到特征之间的交互作用&#xff0c;由此模型灵活性受限。泛化性和灵活性之间的基本权…

JavaSE基础50题:20. 创建一个int类型的数组,元素为100,并把每个元素依次设置为1 - 100

概述 数组练习题 创建一个int类型的数组,元素为100,并把每个元素依次设置为1 - 100. 代码 public static void main(String[] args) {int[] array new int[100]; //没有赋值的情况下&#xff0c;里面存的是100个0//获取数组的长度,依次赋值for (int i 0; i < array.len…

P1 Qt的认识及环境配置

目录 前言 01 下载Qt Creator windows下载安装包拷贝到Linux Linux直接下载 02 Linux 安装Qt 前言 &#x1f3ac; 个人主页&#xff1a;ChenPi &#x1f43b;推荐专栏1: 《C_ChenPi的博客-CSDN博客》✨✨✨ &#x1f525; 推荐专栏2: 《Linux C应用编程&#xff08;概念类…

HarmonyOS4.0开发应用(三)【ArkUI组件使用】

ArkUI组件使用 这里会详细演示以下组件使用: ImageTextTextInputButtonSliderColumn&&RowList自定义组件以及相关函数使用 Image 可以是网络图片、可以是本地图片、也可以是像素图 Image("https://ts1.cn.mm.bing.net/th?idOIP-C.cYA-_PINA-ND9OeBaolDTwHaHa&…

查看电脑cuda版本

1.找到NVODIA控制面板 输入NVIDIA搜索即可 出现NVIDIA控制面板 点击系统信息 2.WINR 输入nvidia-smi 检查了一下&#xff0c;电脑没用过GPU&#xff0c;连驱动都没有 所以&#xff0c;装驱动…… 选版本&#xff0c;下载 下载后双击打开安装 重新输入nvidia-smi 显示如下…

【Lidar】Python实现点云CSF布料滤波算法提取地面点

这两天会持续更新一下Python处理点云数据的教程&#xff0c;大家可以点个关注。今天给大家分享一下点云的经典算法&#xff1a;CSF布料模拟算法。 1 CSF算法简介 CSF算法&#xff0c;全称为Cloth Simulation Filtering&#xff0c;是一种基于欧几里得空间中最小生成树思想的聚类…

iPaaS架构深入探讨

在数字化时代全面来临之际&#xff0c;企业正面临着前所未有的挑战与机遇。技术的迅猛发展与数字化转型正在彻底颠覆各行各业的格局&#xff0c;不断推动着企业迈向新的前程。然而&#xff0c;这一数字化时代亦衍生出一系列复杂而深奥的难题&#xff1a;各异系统之间数据孤岛、…

生成式人工智能在采购场景落地 隆道AI产品亮相甲子引力年终盛典

11月30日&#xff0c;以“致追风赶月的你”为主题的“2023甲子引力年终盛典”在北京举办。北京隆道网络科技有限公司总裁吴树贵受邀出席本次会议&#xff0c;并在企业数字化专场会议中做主题发言&#xff0c;探讨了人工智能在采购业务场景中的应用&#xff0c;重点向参会人员介…