网络时间服务器

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

       使用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进行时间同步的。

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

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

相关文章

杰卡德的故事

三个男人分别是杰卡德距离 杰卡德相似系数和杰卡德系数 杰卡德相似系数和杰卡德距离是互为相反数的。 杰卡德系数和杰卡德距离是不是一回事 感觉是一回事

DevOps搭建(二)-阿里云镜像仓库的使用详解

博主介绍:Java领域优质创作者,博客之星城市赛道TOP20、专注于前端流行技术框架、Java后端技术领域、项目实战运维以及GIS地理信息领域。 🍅文末获取源码下载地址🍅 👇🏻 精彩专栏推荐订阅👇🏻…

NVIDIA A100 PCIE 40GB k8s-device-plugin install in kubernetes

文章目录 1. 目标2. 简介2.1 英伟达 A100 技术规格2.2 架构优势2.3 显卡跑分对比2.4 英伟达 A100 与 kubernetes 3. 安装 NVIDIA A100 GPU 40G 硬件4. NVIDIA R450 datacenter driver5. NVIDIA Container Toolkit6. 创建 runtimeclass5. MIG Strategies6. 配置仓库7. 下载镜像8…

Spring cloud - 断路器 Resilience4J

其实文章的标题应该叫 Resilience4J,而不是Spring Cloud Resilience4J,不过由于正在对Spring cloud的一系列组件进行学习,为了统一,就这样吧。 概念区分 首先区分几个概念 Spring cloud 断路器:Spring Cloud的官网对…

02_Web开发基础之JavaScript

Web开发基础之JavaScript 学习目标和内容 1、能够描述Javascript的作用 2、能够使用分支结构if语句逻辑判断 3、能够使用其中一种循环语句 4、能够定义javaScript中的函数 5、能够定义javaScript中的对象 6、能够描述DOM的作用 7、能够通过DOM操作HTML标签元素及其属性 8、能够…

走进暄桐教室 一起观看暄桐同学作品及感受

暄桐是一间传统美学教育教室,创办于2011年,林曦是创办人和授课老师,教授以书法为主的传统文化和技艺,旨在以书法为起点,亲近中国传统之美,以实践和所得,滋养当下生活。其实,暄桐教室…

数据结构与算法—查找算法(线性查找、二分查找、插值查找、斐波那契查找)

查找算法 文章目录 查找算法1. 线性查找算法2. 二分查找算法2.1 二分查找思路分析2.2 应用实例 3. 插值查找3.1 基本原理3.2 应用实例 4. 斐波那契4.1 基本原理4.2 应用实例 5. 查找总结 在java中,常用的查找有四种: 顺序(线性)查找二分查找/折半查找插值…

广州华锐互动:汽车电子线束加工VR仿真培训与实际生产场景相结合,提高培训效果

随着科技的不断发展,虚拟现实(VR)技术已经逐渐渗透到各个领域,为企业和个人带来了前所未有的便利。在汽车制造行业中,线束加工作为一项关键的生产工艺,其质量直接影响到汽车的性能和安全。因此,…

基于中小微企业_个体工商户的信贷评分卡模型和用户画像(论文_专利_银行调研建模使用)

背景介绍 信用贷款是指由银行或其他金融机构向中小微企业和个体工商户提供的一种贷款产品。该贷款的特点是无需提供抵押品或担保,主要依据借款人的信用状况来进行评估和审批。 中小微企业和个体工商户信用贷款的申请流程相对简单,申请人只需要提供个人…

MySQL数据库的基础概念

目录 顾名思义,数据库是用于存储数据的,那这些数据被存储在哪呢? 文件也能存储数据,那在这个基础上,为什么还要搞出一个数据库来存储数据呢? MySQL的客户端登录/退出指令、服务端的启动/关闭指令 数据…

如何查看PHP信息

创建一个 PHP 文件&#xff0c;比如 info.php&#xff0c;在其中添加以下代码&#xff1a; <?php phpinfo(); ?>访问这个文件&#xff08;例如&#xff0c;在浏览器中输入 http://localhost/info.php&#xff09;&#xff0c;它会显示 PHP 的所有配置信息。在这个页面…

服务器挖矿木马识别与清理

一、什么是挖矿木马 挖矿木马会占用CPU进行超频运算,从而占用主机大量的CPU资源,严重影响服务器上的其他应用的正常运行。黑客为了得到更多的算力资源,一般都会对全网进行无差别扫描,同时利用SSH爆破和漏洞利用等手段攻击主机。部分挖矿木马还具备蠕虫化的特点,在主机被成…

Threejs利用着色器编写动态飞线特效

一、导语 动态飞线特效是可视化数据地图中常见的需求之一&#xff0c;鼠标点击的区块作为终点&#xff0c;从其他区块飞线至点击区块&#xff0c;附带颜色变换或者结合粒子动画 二、分析 利用创建3点来构成贝塞尔曲线&#xff0c;形成线段利用着色器材质来按照线段以及时间…

Go语言学习:第1天

一、为什么开始学go语言 我自己是做测试的&#xff0c;所测试项目使用的是go语言。开始学习go语言的原因有两个&#xff1a;一方面&#xff0c;为了更好的做好工作&#xff1b; 另一方面&#xff0c;为了提高自己的核心竞争力。 二、第1天学习到的内容 2.1 Go是怎么解决包依…

ospf 知识总结

ospf 知识总结 一、ospf的概念 - 开放式最短路径优先协议&#xff0c;是广泛使用的一种动态路由协议&#xff0c;它属于链路状态路由协议&#xff0c;是一个内部网关协议&#xff08;IGP&#xff09;&#xff0c;用于在单一自治系统&#xff08;AS&#xff09;内决策路由。 - …

DeepMind大型语言AI模型FunSearch在数学科学中取得新发现

大型语言模型 (LLM) 是有用的助手 – 它们擅长组合概念&#xff0c;并且可以阅读、编写和编码来帮助人们解决问题。但他们能发现全新的知识吗&#xff1f;由于法学硕士已被证明会“幻觉”事实上不正确的信息&#xff0c;因此利用它们来做出可验证的正确发现是一个挑战。 FunSea…

HarmonyOS:使用MindSpore Lite引擎进行模型推理

场景介绍 MindSpore Lite 是一款 AI 引擎&#xff0c;它提供了面向不同硬件设备 AI 模型推理的功能&#xff0c;目前已经在图像分类、目标识别、人脸识别、文字识别等应用中广泛使用。 本文介绍使用 MindSpore Lite 推理引擎进行模型推理的通用开发流程。 基本概念 在进行开…

各技术栈需要掌握的知识

一、前端工程师需要掌握的知识 前端工程师需要掌握的知识主要包括以下几个方面: HTML、CSS和JavaScript:这是前端工程师的基础知识,需要熟练掌握。HTML是网页的骨架,CSS是网页的外观和样式,JavaScript则是实现网页交互效果的关键。响应式设计:随着移动设备的普及,响应…

测试用例设计方法之判定表详解!!

理论部分 判定表是分析和表达多种输入条件下系统执行不同动作的工具&#xff0c;它可以把复杂的逻辑关系和多种 条件组合的情况表达得既具体又明确。 条件桩(Condition Stub)动作桩(Action Stub&#xff09;条件项(Condition Entry&#xff09;动作项(Action Entry&#xff0…

Linux(4)-LAMP

L-LinuxA-apache/nginxM-mysqlp-php 搭建LAMP以及使用discuz搭建论坛网站 安装apache yum install httpd -y // 安装service httpd start // 启动Apache通过netstat -tunlp查看apache运行的端口&#xff0c;然后打开虚拟机ip 80端口能看到以下页面 或者 安装Mysql centOS6…