网络时间服务器

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

       使用chrony配置时间服务器

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

1 时间同步的必要性

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

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

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

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

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

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

2 配置时间服务器

        实验拓扑图如图所示。

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

        在安装系统时,如果已经选择了图形化界面,则默认已经把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.8.0/24。

把#allow 192.168.0.0/16修改为allow 192.168.8.0/24

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

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

把#local stratum 10修改为local stratum 10

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

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

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

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

[root@redhat8 ~]# systemctl restart chronyd
[root@redhat8 ~]# systemctl enable chronyd

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

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

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

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

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

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

3 配置chrony客户端

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

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

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

由原来的pool 2.rhel.pool.ntp.org iburst改为pool 192.168.184.100 iburst

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

        (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的方式更新时间。

        保存退出并重启 chronyd服务,命令如下。

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

        保存退出并重启 chronyd服务,命令如下。

[root@red-hat8 ~]# systemctl restart chronyd.service 
[root@red-hat8 ~]# systemctl restart enable.service 

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

[root@red-hat8 ~]# ssh-keygen -N "" -f /root/.ssh/id_rsa
Generating public/private rsa key pair.
Created directory '/root/.ssh'.

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

[root@red-hat8 ~]# ssh-copy-id 192.168.184.100

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

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

[root@red-hat8 ~]# date -s "2023-11-13 12:00:00 " ; hwclock -w
2023年 11月 13日 星期一 12:00:00 CST

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

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

[root@red-hat8 ~]# systemctl restart chronyd.service 
[root@red-hat8 ~]# date ; ssh 192.168.184.100 date
2023年 12月 13日 星期三 12:25:14 CST
2023年 12月 13日 星期三 12:25:17 CST

        可以看到,时间很快就同步了,因为这是通过step的方式同步的。

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

[root@red-hat8 ~]# date -s "2023-11-13 12:26:00 " ; hwclock -w
2023年 11月 13日 星期一 12:26:00 CST
[root@red-hat8 ~]# 
[root@red-hat8 ~]# date ; ssh 192.168.184.100 date
2023年 11月 13日 星期一 12:26:09 CST
2023年 12月 13日 星期三 12:26:33 CST

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

        此时重启 chronyd服务,也不会保持时间同步,命令如下。

[root@red-hat8 ~]# systemctl restart chronyd.service 
[root@red-hat8 ~]# date ; ssh 192.168.184.100 date
2023年 12月 13日 星期三 12:29:15 CST
2023年 12月 13日 星期三 12:29:39 CST

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

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

[root@red-hat8 ~]# chronyc makestep 
200 OK
[root@red-hat8 ~]# date ; ssh 192.168.184.100 date
2023年 12月 13日 星期三 13:34:26 CST
2023年 12月 13日 星期三 13:34:29 CST

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

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

​​​​​​​

         可以看到,server2是向192.168.26.101进行时间同步的。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

若依打包将vue放到.jar里面部署

1.vue静态文件,以及单页面 ruoyi-admin\src\main\resources\static \ruoyi-admin\src\main\resources\templates 2.后台开放白名单 "/cms", "/cms#/login" 3. mvc访问vue页面入口,接口 package com.ruoyi.web.controller.syst…

08_CSS定位与综合案例开发

day08_CSS定位与&综合案例开发 Objective(本课目标) 理解什么是定位能说出为什么要用定位 1. 为什么使用定位 标准流在最底层 (海底) ------- 浮动的盒子在中间层 (海面) ------- 定位的盒子 在 最上层 (天空) 小黄色块在…

软件测试面试八股文,最常见的7个高频面试题(附答案,建议收藏)

问题1:请自我介绍下? 核心要素:个人技能优势工作背景经验亮点 参考回答: 第一种:基本信息离职理由 面试官您好,我叫张三,来自番茄市,在软件测试⾏业有 3 年的⼯作经验。做过 Web…

算法——动态规划(DP,Dynamic Programming)

一、基础概念 DP的思想: 把问题分成子问题,前面子问题的解决结果被后面的子问题使用DP与分治法的区别: 分治法把问题分成独立的子问题,各个子问题能独立解决 自顶向下DP前面子问题的解决结果被后面的子问题使用,子问题…

3090K MOSFET N通道沟槽功率 PWM应用

3090K 采用沟槽技术&#xff0c;提供活x氧(导通)&#xff0c;低栅J电荷和栅J电压低至4.5V的工作。3090K 设备适用于各种应用。 3090K 特性&#xff1a; ● VDS 30V,ID 86A RDS(ON) < 5 mΩ VGS 10V RDS(ON) < 9.5mΩ VGS 4.5V ● 高功率和电流处理能力 ● 获得无…

【性能测试】基础知识篇-压力模型

常见压力模式 并发模式&#xff08;即虚拟用户模式&#xff09;和RPS模式&#xff08;即Requests Per Second&#xff0c;每秒请求数&#xff0c;吞吐量模式&#xff09;。 本文介绍这两种压力模式的区别&#xff0c;以便根据自身业务场景选择更合适的压力模式。 并发模式 …

C++面向对象(OOP)编程-模板

本文主要讲解C的模板&#xff0c;其中包括模板的分类&#xff0c;函数模板和类模板&#xff0c;以及类模板与友元函数关系引起的几种关系。强调提供代码来搞懂C模板这一泛型编程手段。 目录 1 C模板 2 模板的本质 3 模板分类 4 函数模板 4.1 函数模板定义格式 4.2 函数模…

下午好~ 我的论文【遥感】(第一期)

写在前面&#xff1a;下午浑浑噩噩&#xff0c;泡杯茶&#xff0c;读篇论文吧 首先说明&#xff0c;时间有限没有那么精力一一回复了&#xff0c;对不起各位了TAT 文章目录 遥感Bi-Dilation-formerCNN-GNN-FusionMulti-hierarchical cross transformerCoupled CNNs 遥感 Bi-D…

Linux---Ubuntu软件安装

1. 软件安装的介绍 Ubuntu软件安装有两种方式: 离线安装(deb文件格式安装&#xff09;在线安装(apt-get方式安装) 2. deb文件格式安装 是 Ubuntu 的安装包格式&#xff0c;可以使用 dpkg 命令进行软件的安装和卸载。 命令说明dpkg安装和卸载deb安装包 dpkg命令选项: 选项…

TestSSLServer4.exe工具使用方法简单介绍(查SSL的加密版本SSL3或是TLS1.2)

一、工具使用方法介绍 工具使用方法参照&#xff1a;http://www.bolet.org/TestSSLServer/ 全篇英文看不懂&#xff0c;翻译了下&#xff0c;能用到的简单介绍如下&#xff1a; 将下载的TestSSLServer4.exe工具放到桌面上&#xff0c;CMD命令行进入到桌面目录&#xff0c;执…

Kafka--从Zookeeper数据理解Kafka集群工作机制

从Zookeeper数据理解Kafka集群工作机制 这一部分主要是理解Kafka的服务端重要原理。但是Kafka为了保证高吞吐&#xff0c;高性能&#xff0c;高可扩展的三高架构&#xff0c;很多具体设计都是相当复杂的。如果直接跳进去学习研究&#xff0c;很快就会晕头转向。所以&#xff0c…

Java小案例-RocketMQ的11种消息类型,你知道几种?(死信消息)

前言 在RocketMQ中&#xff0c;死信消息&#xff08;Dead-Letter Message&#xff09;是指那些在正常情况下无法被消费者消费的消息。这些消息会被存储在死信队列&#xff08;Dead-Letter Queue&#xff0c;简称DLQ&#xff09;中。 死信消息的特性包括&#xff1a; 不会再被…

如何免费搭建私人电影网站(一)

前言&#xff1a;在线看电影经常会出现烦人的广告&#xff0c;为了不浪费时间看广告&#xff0c;有必要做自己的专属网站。 准备工作&#xff1a; 1、申请免费域名&#xff08;也可以花钱注册域名相对稳定&#xff09;链接: 申请免费域名方法 2、申请免费主机&#xff08;也可以…

详解 Jeecg-boot 框架如何配置 elasticsearch

目录 一、下载安装 Elasticsearch 1、 地址&#xff1a;https://www.elastic.co/cn/downloads/elasticsearch 2、下载完成后&#xff0c;解压缩&#xff0c;进入config目录更改配置文件 3、 修改配置完成后&#xff0c;前往bin目录启动el 4、访问&#xff1a;localhost:92…

FreeRTOS202212 ‐ 定时器结构体定义

FreeRTOS202212-定时器结构体 /*-----------------------------------------------------------*/ /* The definition of the timers themselves. */ /*定时器本身的定义*/ typedef struct tmrTimerControl /* The old naming convention is used to prevent breaking kernel a…

分布式事务--TC服务的高可用和异地容灾

1.模拟异地容灾的TC集群 计划启动两台seata的tc服务节点&#xff1a; 节点名称ip地址端口号集群名称seata127.0.0.18091SHseata2127.0.0.18092HZ 之前我们已经启动了一台seata服务&#xff0c;端口是8091&#xff0c;集群名为SH。 现在&#xff0c;将seata目录复制一份&…

音视频学习(二十一)——rtmp收流(tcp方式)

前言 本文主要介绍rtmp协议收流流程&#xff0c;在linux上搭建rtmp服务器&#xff0c;通过自研的rtmp收流库发起取流请求&#xff0c;使用ffmpegqt实现视频流的解码与播放。 关于rtmp协议基础介绍可查看&#xff1a;https://blog.csdn.net/www_dong/article/details/13102607…

《点云处理》平面拟合

前言 在众多点云处理算法中&#xff0c;其中关于平面拟合的算法十分广泛。本篇内容主要是希望总结归纳各类点云平面拟合算法&#xff0c;并且将代码进行梳理保存。 环境&#xff1a; VS2019 PCL1.11.1 1.RANSAC 使用ransac对平面进行拟合是非常常见的用法&#xff0c;PCL…

C语言实现输入一个 N*N 矩阵,并将矩阵转置输出

完整代码&#xff1a; //输入一个 N*N 矩阵&#xff0c;并将矩阵转置输出 #include<stdio.h> #include<stdlib.h>int main(){int n0;printf("请输入矩阵的行数:");scanf("%d",&n);//C语言不允许对数组的大小作动态定义// int arr[n][n];直…

Linux之FTP 服务器

一、FTP服务器匿名账户服务器配置 1、测试是否已安装vsftp服务器&#xff1a; 2、启动vsftp服务器&#xff1a; 3、修改vsftp主配置文件&#xff0c;允许匿名登录 4、重新启动vsftpd服务,禁用防火墙 5、打开FTP服务的数据文件存放目录/var/ftp&#xff0c;复制若干文件到该目…