RHEL8_Linux网络时间服务器

news2024/11/18 11:37:45

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

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

1.时间同步的必要性

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

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

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

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

2.配置时间服务器

实验拓扑图如图所示。

这里把 node01配置成时间服务器,node03作为客户端向node01进行时间同步

        在安装系统时,如果已经选择了图形化界面,则默认已经把chrony这个软件安装上了(如果有安装,请先看后面的软件包管理章节,然后自行安装上去)。
     
   使用vim编辑器打开/etc/chrony.conf,只修改我们能用的几行。         

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.182.0/24。
allow 192.168.182.0/24
        node01 配置成时间服务器之后,只允许192.168.182.0/24网段的客户端进行时间同步。如
果要允许所有客户端都能向此时间服务器进行时间同步,可以写成allow 0/0或allow all。

3)把local stratum 前的注释符#去掉。
local stratum 10
        这行的意思是,即使服务器本身没有和时间服务器保持时间同步,也可以对外提供时间服 务,这行注释要取消。
保存退出,去除空白行和注释行之后,最后修改完成的代码如下,加粗字是修改的内容。
[root@node01 ~]# egrep -v "^#|^$" /etc/chrony.conf 
pool 127.127.1.0 iburst
driftfile /var/lib/chrony/drift
makestep 1.0 3
rtcsync
allow 192.168.182.0/24
local stratum 10
keyfile /etc/chrony.keys
leapsectz right/UTC
logdir /var/log/chrony
[root@node01 ~]# 
4)然后重启chronyd这个服务(注意,这里是chronyd而不是chrony),并设置开机自动启动,命令如下。
[root@node01 ~]# systemctl restart chronyd
[root@node01 ~]# systemctl enable chronyd
[root@node01 ~]# 
5)chrony用的是UDP的123和323,命令如下。
[root@node01 ~]# netstat -anutlp | grep chrony
udp        0      0 0.0.0.0:123             0.0.0.0:*                           2728/chronyd        
udp        0      0 127.0.0.1:323           0.0.0.0:*                           2728/chronyd        
udp6       0      0 ::1:323                 :::*                                2728/chronyd        
[root@node01 ~]# 
6)在防火墙中把这两个端口开放,命令如下。
[root@node01 ~]# firewall-cmd --add-port=123/udp --permanent 
success
[root@node01 ~]# firewall-cmd --add-port=323/udp --permanent 
success
[root@node01 ~]# firewall-cmd --reload 
success
[root@node01 ~]# 
        这里加上 --permanent选项的目的是让其永久生效,然后通过reload重新加载防火墙规则, 让其也立即生效。防火墙的具体设置后面有专门章节讲解。

至此,用chrony搭建的时间服务器完成。
3.配置chrony客户端
        把node02配置成时间服务器的客户端,也就是chrony客户端。
        在node02(IP地址为192.168.182.200)上用vim编辑器修改/etc/chrony.conf,修改下面的
几行
1)修改pool那行,指定要从哪台时间服务器同步时间。
pool 192.168.182.200 iburst
这里指定时间服务器为192.168.182.200,即向192.168.182.200进行时间同步。
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
        如果客户端和服务器的时间相差200秒以上,就认为二者时间相差较多,则通过step的方式更新时间。
3)保存退出并重启 chronyd服务,命令如下。
[root@node03 ~]# systemctl restart chronyd.service 
[root@node03 ~]# systemctl enable chronyd.service 
4)为了更细致地看到两台机器的时间差,先配置ssh使得node03可以无密码登录到node01,先生成密钥对,命令如下。
[root@node03 ~]# ssh-keygen -N "" -f /root/.ssh/id_rsa
Generating public/private rsa key pair.
Created directory '/root/.ssh'.
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:NcEoTMq1ba5D8pch/yL+GQiFGN4rcq3W3X4uxJK5Js4 root@node03
The key's randomart image is:
+---[RSA 3072]----+
|  .  oo  o.      |
| . = +oo. ..     |
|  o = o.o o      |
|   . o o . .     |
|. o = o+S        |
| o + *+*oo       |
|  o . *+*        |
| . .. ++o+.      |
|   .E+.o+=o      |
+----[SHA256]-----+
[root@node03 ~]# 
5)配置到node01的密钥登录,命令如下。
[root@node03 ~]# ssh-copy-id 192.168.182.200
6)给node03上通过date命令设置时间,使得node03和node01的时间相差200秒,命令如下
[root@node03 ~]# date -s "2023-12-07 16:38:00" ; hwclock -w
2023年 12月 07日 星期四 16:38:00 CST
[root@node03 ~]# 
7)然后同时显示两台机器的时间,命令如下。
[root@node03 ~]# date ; ssh 192.168.182.200 date 
2023年 12月 07日 星期四 16:38:46 CST
2023年 12月 07日 星期四 16:36:16 CST
[root@node03 ~]# 
可以看到,时间相差了约30分钟,即180秒。
8)然后重启node02的chronyd服务,等待几秒之后再次查看。
[root@node03 ~]# systemctl restart chronyd.service 
[root@node03 ~]# date ; ssh 192.168.182.200 date 
2023年 12月 07日 星期四 16:39:01 CST
2023年 12月 07日 星期四 16:39:01 CST
[root@node03 ~]# 
可以看到,时间很快就同步了,因为这是通过step的方式同步的。
9)再次修改时间,命令如下。
[root@node03 ~]# date -s "2023-12-07 16:43:00" ; hwclock -w
2023年 12月 07日 星期四 16:43:00 CST
[root@node03 ~]# date ; ssh 192.168.182.200 date 
2023年 12月 07日 星期四 16:43:15 CST
2023年 12月 07日 星期四 16:41:42 CST
[root@node03 ~]# 
        两台机器的时间相差1分40秒,即100秒,这个值低于200秒,即在makestep的阙值范围之内,此时客户端向服务器进行时间同步时只能通过slew的方式同步。
10)此时重启 chronyd服务,也不会保持时间同步,命令如下。
[root@node03 ~]# systemctl restart chronyd.service 
[root@node03 ~]# 
[root@node03 ~]# date ; ssh 192.168.182.200 date 
2023年 12月 07日 星期四 16:44:12 CST
2023年 12月 07日 星期四 16:42:39 CST
[root@node03 ~]# 
可以看到,并没有同步,因为slew同步的速度比较慢。

11)此时如果通过执行chronyc makestep命令手动step同步,则会立即同步时间,命令如下。
[root@node03 ~]# chronyc makestep 
200 OK
[root@node03 ~]# date ; ssh 192.168.182.200 date 
2023年 12月 07日 星期四 16:43:44 CST
2023年 12月 07日 星期四 16:43:44 CST
[root@node03 ~]# 
这样就可以看到立即同步成功了

12)通过chronye -n sources -v查看现在的同步状况,如图20-4所示。

可以看到,node02是向192.168.182.200进行时间同步的。

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

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

相关文章

如何选择合适的运筹优化求解器?

文章目录 前言求解器对比问题延伸:商用求解器和开源求解器的差别是什么? 求解器PK总结参考资料 前言 求解器对于运筹算法工程师而言,常常像一个黑盒,我们扔进去输入数据和数学模型,求解器给我们吐出一个解出来。这种状…

类与对象的概念:创建及调用方法

掌握类和创建对象的关系 定义类 定义对象 定义和调用方法 编程思想:面向过程编程,面向对象编程 系统提供数据类型【String,char,double】,我们也可以自己定义类型:根据自定义类型所衍生出来的变量就是…

【推荐系统】推荐算法数学基础

【大家好,我是爱干饭的猿,本文重点介绍推荐系统涉及的数学知识、推荐系统涉及的概率统计知识。 后续会继续分享其他重要知识点总结,如果喜欢这篇文章,点个赞👍,关注一下吧】 上一篇文章:《【推…

RocketMq顺序消息

RocketMq顺序消息 1.RocketMq 架构图2.RocketMq顺序消息2.1部分消息有序2.1.1 生产者构建2.1.2 生产者保证有序2.1.3 消费者保证有序性 3.使用rocketmq-spring-boot-starter发送消息如何指定tag与key?问题1.MessagingException: sendDefaultImpl call timeout 1.RocketMq 架构…

高精度加法,减法,乘法,除法(下)(C语言)

前言 上一篇博客我们分享了高精度加法,减法,这一期我将为大家讲解高精度乘法和高精度除法。那让我们开始吧! 对加法和减法感兴趣的话就点我 文章目录 1,乘法2,除法3,尾声 1,乘法 让我们想想我们平时做数学…

STC15F100E单片机模拟串口

文章目录 一、芯片简介二、开发环境三、软件模拟串口参考 一、芯片简介 STC15F100系列单片机是宏晶科技生产的单时钟/机器周期(1T)的单片机,新一代8051单片机,指令代码完全兼容传统8051,但是速度快6-12倍。 内部集成R/C时钟,5MHz…

52 代码审计-PHP项目类RCE及文件包含下载删除

目录 漏洞关键字:演示案例:xhcms-无框架-文件包含跨站-搜索或应用-includeearmusic-无框架-文件下载-搜索或应用功能-down等zzzcms-无框架-文件删除RCE-搜索或应用-unlink、eval 漏洞关键字: SQL注入: select insert update mysql_query mysql等 文件上传&#xff…

守护安全,六氟化硫气体泄漏报警装置校准服务

在电力工业中,六氟化硫(SF6)气体是一种重要的介质,它用作封闭式中、高压开关的灭弧和绝缘气体。六氟化硫气体的卓越性能实现了装置经济化、低维护化的操作。与普通装置相比,可以节省最多90%的空间。 六氟化…

Themis: Fast, Strong Order-Fairness in Byzantine Consensus

目录 笔记后续的研究方向摘要引言秩序井然 Themis: Fast, Strong Order-Fairness in Byzantine Consensus CCS 2023 笔记 后续的研究方向 摘要 我们介绍了Themis,这是一种将交易的公平排序引入(许可的)拜占庭共识协议的方案,最…

ubuntu系统下搭建本地物联网mqtt服务器的步骤

那么假如我们需要做一些终端设备,例如温湿度传感器、光照等物联网采集设备要接入呢?怎么样才能将数据报送到服务器呢? 以下内容基于我们ubuntu系统下的emqx成功启动的基础上。我们可以用浏览器键入控制板的地址,如果启动成功&…

python pyaudio显示音频波形图

python pyaudio显示音频波形图 代码如下: import numpy as np import matplotlib.pylab as plb import wave# 读取 wav wf wave.open("./output.wav", "rb")# 获取音频相关参数:声道数、量化位数、采样频率、采样帧数 nchannels,…

案例二:SQL Server数据库的备份和还原

1、备份类型。 在 SQL Server 中提供了三种常用的备份类型,分别是完整备份.差异备份和事务日志备份。 完整备份: 完整备份包括对整个数据库、部分事务日志、数据库结构和文件结构的备份。完整备份代表的是备份完成时刻的数据库。 完整备份是…

「Verilog学习笔记」格雷码计数器

专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点,刷题网站用的是牛客网 timescale 1ns/1nsmodule gray_counter(input clk,input rst_n,output reg [3:0] gray_out );reg [3:0] binary_cnt ; reg flag ; always (posedge clk or negedge r…

【高效开发工具系列】Mac删除启动台图标

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

IP地址如何用于流量管理?

随着互联网的普及和网络流量的不断增加,流量管理成为了网络运营中至关重要的一环。而IP地址作为互联网中的重要标识符,也可以被广泛应用于流量管理中。 IP地址是互联网协议(IP)中用于标识和定位网络设备的32位二进制地址。通过IP地…

Redis Reactor事件驱动模型源码

前置学习:Redis server启动源码-CSDN博客 Redis采用单线程Reactor模型 三个关键角色,即 reactor、acceptor、handler 三类处理事件,即连接事件、写事件、读事件。 建立连接(Acceptor)、监听accept、read、write事件…

使用高防IP防护有哪些优势

高防IP是针对互联网服务器在遭受大流量的DDoS攻击后导致服务不可用的情况下,推出的付费增值服务,用户可以通过配置高防IP,将攻击流量引流到高防IP,确保源站的稳定可靠。高防IP相当于搭建完转发的服务器。 高防IP有两种接入方式&a…

《Easy3d+Qt+VTK》学习

《Easy3dQtVTK》学习-1、编译与配置 一、编译二、配置注 一、编译 1、 资源下载:easy3d giuhub 2、解压缩 3、用qt打开CMakeLists.txt即可 4、点击项目,选择debug或者release,图中3处可自行选择,因为我的qt版本是6&#xff0c…

unity 2d 入门 飞翔小鸟 小鸟跳跃 碰撞停止挥动翅膀动画(十)

1、切换到动画器 点击make transition和exit关联起来 2、设置参数 勾选掉Has Exit Time 3、脚本给动画器传参 using System.Collections; using System.Collections.Generic; using UnityEngine;public class Fly : MonoBehaviour {//获取小鸟(刚体)p…

云原生系列1

1、虚拟机集群环境准备 VirtualBox类似vmware的虚拟化软件,去官网https://www.virtualbox.org/下载最新版本免费的,VirtualBox中鼠标右ctrl加home跳出鼠标到wins中。 VirtualBox安装步骤 https://blog.csdn.net/rfc2544/article/details/131338906 cent…