了解linux网络时间服务器

本章主要介绍网络时间服务器。
  • 使用chrony配置时间服务器
  • 配置chrony客户端向服务器同步时间
20.1 时间同步的必要性
些服务对时间要求非常严格,例如,图20-1所示的由三台服务器搭建的ceph集群。
这三台服务器的时间必须保持一致,如果不一致,就会显示警告信息。那么。如何能让这
三台服务器的时间保持一致呢?手动调整时间的方式肯定不行,因为手动调整时间最多只能
精确到分,很难精确到秒。而且即使现在时间调整一致了,过一段时间之后,时间可能又不一
样了。
所以,需要通过设置让这些服务器的时间能够自动同
步,如图20-2所示。

 

这里假设我们有一个时间服务器时间为7:00,设置
server1和 server2向此时间服务器进行时间同步。
假设serverl 当前时间为6;59,它与时间服务器一对
比,“我的时间比时间服务器慢了一分钟”,然后它主板上的晶体芯片就会跳动得快一些,很快
就“追”上了时间服务器的时间。
假设server2当前时间是7:01,它与时间服务器一对比,“我竟然比时间服务器快了一分
钟”,然后它主板上的晶体芯片就会跳动得慢一些,“等着”时间服务器。
下面就开始使用chrony来配置时间服务器。
20.2 配置时间服务器
这里把 server配置成时间服务器,server2作为客户端向server进行时间同步。
在安装系统时,如果已经选择了图形化界面,则默认已经把
chrony这个软件安装上了(如果没有安装,请先看后面的软件
包管理章节,然后自行安装上去)。
使用vim编辑器打开/etc/chrony.conf,只修改我们能用的几
行。
(1)指定所使用的上层时间服务器。
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.248.0/24。
把#allow 192.168.0.0/16修改为allow 192.168.8.0/24
server 配置成时间服务器之后,只允许192.168.248.0/24网段的客户端进行时间同步。如
果要允许所有客户端都能向此时间服务器进行时间同步,可以写成allow 0/0或allow all。
(3)把local stratum 前的注释符#去掉。
1 把#local stratum 10修改为local stratum 10
这行的意思是,即使服务器本身没有和时间服务器保持时间同步,也可以对外提供时间服
务,这行注释要取消。
保存退出,去除空白行和注释行之后,最后修改完成的代码如下,加粗字是修改的内容。
[root@pp ~]# egrep -v "^#|^$" /etc/chrony.conf 
pool 127.127.1.0 iburst
driftfile /var/lib/chrony/drift
makestep 1.0 3
rtcsync
allow 192.168.248.0/16
local stratum 10
keyfile /etc/chrony.keys
leapsectz right/UTC
logdir /var/log/chrony
[root@pp ~]# 
然后重启chronyd这个服务(注意,这里是chronyd而不是chrony),并设置开机自动启动,
命令如下。
[root@pp ~]# systemctl restart chronyd
[root@pp ~]# systemctl enable chronyd
Created symlink /etc/systemd/system/multi-user.target.wants/chronyd.service → /usr/lib/systemd/system/chronyd.service.
[root@pp ~]# 
chrony用的是UDP的123和323,命令如下。
[root@pp ~]# netstat -nutlp | grep chronyd
udp        0      0 0.0.0.0:123             0.0.0.0:*                           4037/chronyd        
udp        0      0 127.0.0.1:323           0.0.0.0:*                           4037/chronyd        
udp6       0      0 ::1:323                 :::*                                4037/chronyd        
[root@pp ~]# 
在防火墙中把这两个端口开放,命令如下。
[root@pp ~]# firewall-cmd --add-port=123/udp --permanent
success
[root@pp ~]# firewall-cmd --add-port=323/udp --permanent
success
[root@pp ~]# firewall-cmd --reload 
success
[root@pp ~]# 
这里加上 --permanent选项的目的是让其永久生效,然后通过reload重新加载防火墙规则,
让其也立即生效。防火墙的具体设置后面有专门章节讲解。
至此,用chrony搭建的时间服务器完成。
20.3 配置chrony客户端
把server2配置成时间服务器的客户端,也就是chrony客户端。
在server2(IP地址为192.168.248.23)上用vim编辑器修改/etc/chrony.conf,修改下面的
几行。
(1)修改pool那行,指定要从哪台时间服务器同步时间。
1 由原来的pool 2.rhel.pool.ntp.org iburst改为pool 192.168.248.45 iburst
这里指定时间服务器为192.168.26.101,即向192.168.26.101进行时间同步。
(2)修改makestep那行,格式如下。
1 makestep 阈值 limit
客户端向服务器同步时间有两种方式:step和 slew。
step:跳跃着更新时间,如时间由1点直接跳到7点。
slew:平滑着移动时间,晶体芯片跳动得快一些,就好比秒针的转速“快进”了一样。
如果客户端和服务器的时间相差较多,则通过step的方式更新时间;如果客户端和服务器
的时间相差不多,则通过slew的方式更新时间。那么,时间相差多或不多的标准是什么呢?
就要看时间差是否超过makestep后面的住值了。
举一个例子,makestep 10 3的意思是,如果客户端和服务器的时间相差10秒以上,就认
为客户端和服务器的时间相差较多,则前三次通过step 的方式更新时间。客户端通过这种方 式会更新得很快,有些应用程序因为时间的突然跳动会带来问题。
如果客户端和服务器的时间相差10秒以内,就认为二者时间相差不多,则通过slew的方
式更新时间。这种方式更新的速度会比较慢,但比较平稳。
1 把原来的makestep 10 3改成makestep 200 3
如果客户端和服务器的时间相差200秒以上,就认为二者时间相差较多,则通过step的方
式更新时间。
保存退出并重启 chronyd服务,命令如下。
[root@up ~]# systemctl restart chronyd.service 
[root@up ~]# systemctl enable chronyd.service 
[root@up ~]# 
为了更细致地看到两台机器的时间差,先配置ssh使得server2可以无密码登录到server。
先生成密钥对,命令如下。
[root@up ~]# ssh-keygen -N "" -f /root/.ssh/id_rsa
Generating public/private rsa key pair.
Created directory '/root/.ssh'.
配置到server的密钥登录,命令如下。
[root@up ~]# ssh-copy-id 192.168.248.45
给server2上通过date命令设置时间,使得server2和server的时间相差200秒,命令如下。
[root@up ~]# date -s "2023-12-07 12:30:00" ; hwclock -w
2023年 12月 07日 星期四 12:30:00 CST
[root@up ~]# 
然后同时显示两台机器的时间,命令如下。
[root@up ~]# date ; ssh 192.168.248.45 date
2023年 12月 07日 星期四 12:30:34 CST
2023年 12月 07日 星期四 20:15:43 CST
[root@up ~]# 
然后重启server2的chronyd服务,等待几秒之后再次查看。
[root@up ~]# date ; ssh 192.168.248.45 date
2023年 12月 07日 星期四 20:17:06 CST
2023年 12月 07日 星期四 20:17:06 CST
[root@up ~]# 
可以看到,时间很快就同步了,因为这是通过step的方式同步的。
再次修改时间,命令如下。
[root@up ~]# date -s "2023-12-07 20:18:00" ; hwclock -w
2023年 12月 07日 星期四 20:18:00 CST
[root@up ~]# date ; ssh 192.168.248.45 date
2023年 12月 07日 星期四 20:18:02 CST
2023年 12月 07日 星期四 20:18:18 CST
[root@up ~]# 
两台机器的时间相差1分40秒,即100秒,这个值低于200秒,即在makestep的阙值范围
之内,此时客户端向服务器进行时间同步时只能通过slew的方式同步。
此时重启 chronyd服务,也不会保持时间同步,命令如下。
[root@up ~]# systemctl restart chronyd.service 
[root@up ~]# date ; ssh 192.168.248.45 date
2023年 12月 07日 星期四 20:19:04 CST
2023年 12月 07日 星期四 20:19:19 CST
[root@up ~]# 
可以看到,并没有同步,因为slew同步的速度比较慢。
此时如果通过执行chronyc makestep命令手动step同步,则会立即同步时间,命令如
下。
[root@up ~]# chronyc makestep 
200 OK
[root@up ~]# date ; ssh 192.168.248.45 date
2023年 12月 07日 星期四 20:20:12 CST
2023年 12月 07日 星期四 20:20:13 CST
[root@up ~]# 
这样就可以看到立即同步成功了。
通过chronye -n sources -v查看现在的同步状况
[root@up ~]# 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.248.45               10   6    37    32    +11ns[+6520ns] +/-  126us
[root@up ~]# 
可以看到,server2是向192.168.248.45进行时间同步的。

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

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

相关文章

Python Django-allauth: 构建全面的用户身份验证系统

更多资料获取 📚 个人网站:ipengtao.com Django-allauth是一个功能强大的Django插件,旨在简化和定制Web应用程序中的用户身份验证和管理。本文将深入介绍Django-allauth的核心功能、基本用法以及实际应用场景,通过丰富的示例代码…

一个newman命令行让某大厂瘫痪半天,速看!

newman简介 newman是为Postman而生,专门用来运行Postman编写好的脚本; 使用newman,你可以很方便的用命令行来执行postman collections。 newman的安装 1.先下载Node.js;https://nodejs.org/en/ 2.安装NodeJs(很容易安装&#x…

Java IO流(二)(字节流FileOutputStream)

IO流体系 InputStream、OutputStream及Reader、Writer都是抽象类。 字节流 FileOutputStream 操作本地文件的字节输出流,可以把程序中的数据写到本地文件中。 FileOutputStream字节输出流的细节 创建字节输出流对象 细节1:参数是字符串表示的路径或者是File对象…

zotero关闭翻译自动创建标签

zotero中文社区:https://plugins.zotero-chinese.com/#/

游戏架构之继承对象模型和组件对象模型

1.概述: 在所有游戏性架构相关的内容中,运行时对象模型可能是最复杂的系统,并且不同的游戏引擎呈现出的差异极大。例如Unity3D提供的组件模型,虚幻引擎提供的面向对象继承模型,其他一些游戏则使用一种不同于两者的基于…

【广州华锐互动VRAR】VR戒毒科普宣传系统有效提高戒毒成功率

随着科技的不断发展,虚拟现实(VR)技术已经逐渐渗透到各个领域,为人们的生活带来了前所未有的便利。在教育科普领域,VR技术的应用也日益广泛,本文将详细介绍广州华锐互动开发的VR戒毒科普宣传系统&#xff0…

12.8作业

1. 使用手动连接,将登录框中的取消按钮使用qt4版本的连接到自定义的槽函数中,在自定义的槽函数中调用关闭函数 将登录按钮使用qt5版本的连接到自定义的槽函数中,在槽函数中判断ui界面上输入的账号是否为"admin",密码是…

Termux+Hexo结合内网穿透轻松实现安卓手机搭建博客网站发布公网访问

文章目录 前言 1.安装 Hexo2.安装cpolar3.远程访问4.固定公网地址 前言 Hexo 是一个用 Nodejs 编写的快速、简洁且高效的博客框架。Hexo 使用 Markdown 解析文章,在几秒内,即可利用靓丽的主题生成静态网页。 下面介绍在Termux中安装个人hexo博客并结合…

接口自动化测试用例

1、接口文档 根据开发、产品的接口文档,以及评审,进行设计接口测试用例,它不像UI测试,有个界面,对于简单的系统,需求文档不提供也能覆盖所有功能,接口测试虽说可以抓包,但抓包无法覆…

【android开发-10】android中四种布局详细介绍

在Android开发中,常见的四种布局分别是:线性布局(LinearLayout)、相对布局(RelativeLayout)、帧布局(FrameLayout)和绝对布局(AbsoluteLayout)。 注意&#…

Numpy数组的运算(第7讲)

Numpy数组的运算(第7讲)         🍹博主 侯小啾 感谢您的支持与信赖。☀️ 🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ…

mazing是什么软件?为什么选择iMazing

说起iOS设备管理工具,可能大家还有点陌生,其实就是Apple公司开发的移动设备,因其的操作系统是独特的iOS系统,所以又叫iOS设备。比如大家都在用的iPhone手机,就是这样类型的一个设备。 mazing是什么软件? iMazing是一…

银河麒麟服务器部署Prometheus+Grafana

#年薪百万# 一、环境准备 操作系统:Operating System: Kylin Linux Advanced Server V10 (Sword) (X86-64) prometheus:prometheus-2.48.0.linux-amd64 grafana:grafana-enterprise-10.2.2.linux-amd64 node_exporter:node_expor…

React 快速实现拖拽改变容器宽高度

一、前言 有时我们需要对一个容器的宽高度进行动态的修改, 最简单直接的方法一般为:用户可以拖拽容器的边缘来改变其大小,例如下面这样的效果: 在react中,我们可以使用re-resizable这个三方库来快速的实现上面的效果…

Python os模块及用法

os 模块代表了程序所在的操作系统,主要用于获取程序运行所在操作系统的相关信息。 在 Python 的交互式解释器中先导入 os 模块,然后输入 os.__all__ 命令(__all__ 变量代表了该模块开放的公开接口),即可看到该模块所包…

2023时代楷模人民艺术家蒋旗作品欣赏

时代楷模是我们生活中的榜样人物,是我们行业内的指路明灯,是传承弘扬中华优秀传统文化的传播者! 弘扬中华优秀传统文化,繁荣中国书画艺术。坚持守正创新,推动书画艺术的创造性转化和创新性发展为优秀书画家搭建更为广…

YOLOv8 YoLov8l 模型输出及水果识别

🍨 本文为[🔗365天深度学习训练营学习记录博客 🍦 参考文章:365天深度学习训练营 🍖 原作者:[K同学啊 | 接辅导、项目定制] 🚀 文章来源:[K同学的学习圈子](https://www.yuque.com/m…

spring boot整合mybatis进行部门管理管理的增删改查

部门列表查询: 功能实现: 需求:查询数据库表中的所有部门数据,展示在页面上。 准备工作: 准备数据库表dept(部门表),实体类Dept。在项目中引入mybatis的起步依赖,mysql的…

同旺科技 USB TO RS-485 定制款适配器--- 拆解(三)

内附链接 1、USB TO RS-485 定制款适配器 ● 支持USB 2.0/3.0接口,并兼容USB 1.1接口; ● 支持USB总线供电; ● 支持Windows系统驱动,包含WIN10 / WIN11系统32 / 64位; ● 支持Windows RT、Linux、Mac OS X、Windo…

Python 案例实训教学,课程展示及结课存档优化|ModelWhale 版本更新

大雪时节,仲冬如约而至,我们也迎来了 ModelWhale 新一轮的版本更新。 本次更新中,ModelWhale 主要进行了以下功能迭代: 优化 课程大纲展示(团队版✓)优化 作业批量导出存档(团队版✓&#xff…