RHCE9学习指南 第19章 网络时间服务器

news2025/1/4 15:09:34

在这里插入图片描述

19.1 时间同步的必要性

对于一些服务来说对时间要求非常严格,例如,图19-1所示由三台服务器搭建的ceph集群。
file
图19-1 三台机器搭建的集群对时间要求比较高

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

所以,需要设置这些服务器的时间能够自动去同步,如图19-2所示。
file
图19-2 通过时间服务器进行时间同步

这里假设我们有一个时间服务器时间为7:00,server1和server2设置好向此时间服务器进行时间的同步。

假设server1当前时间为6:59,它跟时间服务器一对比,“我的时间比时间服务器慢了一分钟”,然后它主板上的晶体芯片就会跳动得快一些,很快就“追”上了时间服务器的时间。

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

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

19.2 配置时间服务器

拓扑图如图19-3所示。

file
图19-3 本章实验拓扑图
这里把server配置成时间服务器,server2作为客户端向server1进行时间同步。

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

#allow 192.168.0.0/16 
改成 
allow 192.168.26.0/24

server配置成时间服务器之后,只允许192.168.26.0/24网段的客户端进行时间同步。如果要允许所有客户端都能向此时间服务器进行时间同步,可以写成allow 0/0 或allow all。
(3)把local stratum前的注释符#去掉。

#local stratum 10 变为local stratum 10

这行的意思是即使服务器本身没有和时间服务器保持时间同步,那么也可以对外提供时间服务,这行注释要取消。
保存退出,去除空白行和注释行之后,最后修改之后的代码如下,黑体字是修改的内容。

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

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

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

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

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

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

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

这里加上选项–permanent的目的是让其永久生效,然后通过reload重新加载防火墙规则,让其立马也生效。具体防火墙的设置后面有专门章节讲解。
至此,用chrony搭建的时间服务器完成。

19.3 配置chrony客户端

把server2配置成时间服务器的客户端,也就是chrony客户端。
在server2(IP为192.168.26.102)上用vim编辑器修改/etc/chrony.conf ,修改下面的几行。
(1)修改pool那行,指定要从哪台时间服务器同步时间。

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

这里指定时间服务器为192.168.26.101,即向192.168.26.101进行同步时间
(2)修改makestep那行,格式如下。
makestep 阈值 limit
客户端向服务器同步时间有两种方式:step和slew。

step:跳跃着更新时间,如时间由1点直接跳到7点。
slew:平滑着移动时间,晶体芯片跳动的快一些,就好比秒针的转速"快镜头"一般。

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

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

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

把原来的makestep 1.0 3 改成:makestep 200 3
如果客户端和时间服务器的时间相差200s以上,则认为时间相差较多,此时会通过step的方式进行调整时间。
保存退出,并重启chronyd服务,命令如下。

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

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

[root@server2 ~]# ssh-keygen -N "" -f /root/.ssh/id_rsa
Generating public/private rsa key pair.
Your identification has been saved in /root/.ssh/id_rsa.
	...输出...
[root@server2 ~]# 

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

[root@server2 ~]# ssh-copy-id 192.168.26.101
	...输出...
root@192.168.26.101's password: 此处输入192.168.26.101的root密码
	...输出...
[root@server2 ~]#

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

[root@server2 ~]# date -s "2023-12-19 23:50:00" ; hwclock -w
20231219日 星期二 23:50:00 CST
[root@server2 ~]# 

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

[root@server2 ~]# date ; ssh 192.168.26.101 date
20231219日 星期二 23:50:08 CST
20231219日 星期二 23:56:34 CST
[root@server2 ~]# 

这里可以看到,时间相差了6分钟,即360s多。
然后重启server2的chronyd服务,等待几秒之后再次查看

[root@server2 ~]# date ; ssh 192.168.26.101 date
20231219日 星期二 23:57:17 CST
20231219日 星期二 23:57:17 CST
[root@server2 ~]# 

可以看到,时间很快就同步了,因为这是通过step的同步方式,会很快。
再次修改时间,命令如下。

[root@server2 ~]# date -s "2023-12-19 00:00:00" ; hwclock -w
20231219日 星期二 00:00:00 CST
[root@server2 ~]# 
[root@server2 ~]# date ; ssh 192.168.26.101 date
20231219日 星期二 00:00:03 CST
20231219日 星期二 00:01:13 CST
[root@server2 ~]#

两台机器的时间相差在1分10s,大概是70s,这个值低于200s,即在makestep的阈值范围之内,此时客户端向服务器进行时间同步时只能使用slew的方式同步。
此时重启chronyd服务,也不会保持时间同步,命令如下。

[root@server2 ~]# date ; ssh 192.168.26.101 date
20231219日 星期二 00:01:54 CST
20231219日 星期二 00:03:03 CST
[root@server2 ~]#

此时可以看到,并没有同步,因为slew同步的速度比较慢。
此时如果通过执行chronyc makestep手动step同步,则会立即同步时间,命令如下。

[root@server2 ~]# chronyc makestep
200 OK
[root@server2 ~]# date ; ssh 192.168.26.101 date
20231219日 星期二 00:05:55 CST
20231219日 星期二 00:05:55 CST
[root@server2 ~]#

这样就可以看到立即同步成功了。
通过chronyc -n sources -v查看现在同步状况,如图20-4所示。
file
图20-4 查看同步状况
这里可以看到,server2是向192.168.26.101进行同步时间的。

作业

配置server2,使其向阿里云的时间服务器同步时间,阿里云时间服务器地址是ntp.aliyun.com。

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

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

相关文章

GPT-4与DALL·E 3:跨界融合,开启绘画与文本的新纪元

在人工智能的发展浪潮中,MidTool(https://www.aimidtool.com/)的GPT-4与DALLE 3的集成代表了一个跨越式的进步。这一集成不仅仅是技术的结合,更是艺术与文字的完美融合,它为创意产业带来了革命性的变革。本文将探讨GPT…

太阳能4G无线灌溉控制器,助力智慧灌溉,节水增产—蜂窝物联网

传统灌溉费时费力,不仅缺乏灌溉程度的把控,而且带来一系列的水资源浪费和土地盐碱化问题。福建蜂窝物联网科技自主研发的太阳能4G无线灌溉控制器应用了物联网技术和移动互联网技术,能实现对灌溉设备的统一管理和远程控制,结合土壤…

期货日数据维护与使用_日数据维护_模块运行演示

写在前面: 本文默认已经创建了项目,如果不知道如何创建一个空项目的,请参看以下两篇博文 PyQt5将项目搬到一个新的虚拟环境中 https://blog.csdn.net/m0_37967652/article/details/122625280 python_PyQt5开发工具结构基础 https://blog.cs…

引领文旅创新_实时云渲染赋能2023湾区文采会元宇宙虚拟展厅

2023年11月3日,2023粤港澳大湾区公共文化和旅游产品(东莞)采购会(下文简称:2023湾区文采会)开幕式在东莞市文化馆举行。本届大湾区文采会以“文采潮流 融合共生”为主题,集聚了科技、时尚、潮流…

贝蒂详解<string.h>(下)

✨✨欢迎大家来到贝蒂大讲堂✨✨ ​​​​🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:C语言学习 贝蒂的主页:Betty‘s blog 目录 1. 简介 2. memset()函数 2.1用法 2.2实例 2.3 实现me…

计算机毕业设计-----SSH校园精品课程网前后台

项目介绍 本项目是很不错的一个校园精品课程网源码,前台和后台源码都有,分为管理员与学生两种角色; 前台功能:网站首页,校园新闻,课程中心,资源下载,互动交流,个人中心…

Spring之整合Mybatis底层源码

文章目录 一、整体核心思路1 . 简介2. 整合思路 二、源码分析1. 环境准备2. 源码分析 一、整体核心思路 1 . 简介 有很多框架需要与Spring进行整合,而整合的核心思路就是把其他框架所产生的对象放到Spring容器中,让其成为一个bean。比如Mybatis&#x…

centenos下载安装

阿里云镜像下载 centos-7-isos-x86_64安装包下载_开源镜像站-阿里云 新建虚拟机 (1) 创建新的虚拟机 可以在主页直接点击创建新的虚拟机也可以在上方,点击文件,新建虚拟机 (2) 选择自定义(高级) (3) 硬盘兼容性 默认即可。我…

大模型商业化的又一条路,小冰闯出来了

当鲁特格尔哈尔饰演的Roy Batty在《银翼杀手》说出那段影史留名的台词时,人类对“复制人”“仿生人”的未来预想,全部凝聚成一个实体化的智能体,在未来很多年里支配着全世界对人工智能、数字生命的想象力。 但到了今天,当现实场景…

【漏洞复现】大华 DSS 数字监控系统 itcBulletin SQL 注入

漏洞描述 大华 DSS存在SQL注入漏洞,攻击者 pota/services/itcBuletin 路由发送特殊构造的数据包,利用报错注入获取数据库敏感信息。攻击者除了可以利用 SQL注入漏词获取数据库中的信息例如,管理员后台密码、站点的用户人人信息)之外,甚至在高权限的情况可向服务器中写入木…

汽车产线设备CAN总线一键刷写方案

汽车产线设备CAN总线一键刷写方案 一、概述 随着汽车工业的不断发展,CAN总线技术在汽车产线设备中得到了广泛应用。然而,在实际生产过程中,设备的软件升级和配置更改是不可避免的。为了提高生产效率,我们推出了一键刷写CAN总线解…

windows11右键菜单-新建文本文档(记事本、txt文件)不见了的修复方法

windows11右键菜单-新建文本文档(记事本、txt文件)不见了的修复方法 修改注册表 1、快捷键 WIN R。 2、输入 regedit 点击确定打开“注册表编辑器”。 3、在上边搜索栏直接输入 \HKEY_CLASSES_ROOT.txt 命令进行搜索后会跳转到指定页面 4、双击 …

计算机毕业设计 | SpringBoot图书管理系统(附源码)

1, 概述 1.1 课题背景 开发一个学生成绩管理系统,采用计算机对学生成绩进行处理,进一步提高了办学效益和现代化水平。为广大教师和学生提高工作效率,实现学生成绩信息管理工作流程的系统化、规范化和自动化。现在我国中学的学生…

Python流程控制语句

目录 一、分支结构 (一)单分支语句 (二)双分支语句 (三)多分支语句 (四)嵌套的分支语句 二、循环结构 循环结构概述 (一)for循环 (二&am…

模板 BIEE(三)如何直接查看表示层列获取的sql语句

举例 想查看如下数据 SELECT 0 s_0, “Financials - AR Overview”.“Facts - AR Turnover”.“Days Sales Outstanding” s_1 FROM “Financials - AR Overview” web查看结果 日志内容如何查看请见《模板 BIEE(二)》 如下是不勾选高速缓存的结果&am…

如何保护linux服务器远程使用的安全

服务器安全是一个非常敏感的问题,因服务器远程入侵导致数据丢失的安全问题频频出现,一旦服务器入侵就会对个人和企业造成巨大的损失。因此,在日常使用服务器的时候,我们需要采取一些安全措施来保障服务器的安全性。 目前服务器系…

尝试添加服务器中正在运行的docker容器时报错:当前用户没有运行“docker”的权限

尝试添加服务器中正在运行的docker容器时报错:当前用户没有运行“docker”的权限 环境 1,通过vscode ssh到服务器的 2,服务器端有一个contianer,但是无法通过vscode的Dev contianer组件将服务器中正在运行的contianer添加过来 3…

适合游泳的骨传导耳机,推荐四款高质量游泳耳机!

游泳是一项全身性的运动,对于锻炼身体和塑形都很有帮助,但是游泳的时候往往会因为水的阻力而感到动作笨拙,同时也会感到枯燥无味。而一款好的游泳耳机则能够让你在游泳的过程中享受音乐或者其他的音频内容,增加游泳的趣味性&#…

Jenkins基础篇--添加用户和用户权限设置

添加用户 点击系统管理,点击管理用户,然后点击创建用户(Create User) 用户权限管理 点击系统管理,点击全局安全配置,找到授权策略,选择安全矩阵,配置好用户权限后,点击…

CROS跨域漏洞复现分析

复现环境:bp官方靶场Lab: CORS vulnerability with basic origin reflection | Web Security Academy 复现过程: 首先以普通用户的身份登录系统: 1、靶场环境点击access the lab 和给定账号wiener:peter 2、使用wiener:peter登录系统&…