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

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

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

相关文章

【征稿倒计时十天】第三届高性能计算与通信工程国际学术会议(HPCCE 2023)

【有ISSN、ISBN号!!往届均已完成EI检索】 第三届高性能计算与通信工程国际学术会议(HPCCE 2023) 2023 3rd International Conference on High Performance Computing and Communication Engineering (HPCCE 2023) 2023年12月22-24日 | 中国哈尔滨 第三…

CSS新手入门笔记整理:CSS溢出声名overflow

通常一个盒子的内容是被限制在盒子边框之内的,但是有时也会溢出,即部 分或者全部内容跑到盒子边框之外。 语法 元素{overflow:取值;} 属性值 说明 visible 若内容溢出,则溢出内容可见(默认值) hid…

数据结构与算法-D5-D7线性表之链表

结点类型描述 程序编写 节点定义 linklist.h linklist.c list_create 1、申请内存 2、赋值 3、返回头结点 list_tail_insert 1、建立一个新结点 2、找尾结点 3、尾部插入 list_show list_insert 链表在某一位置的插入 1、调用算法list_get 2、插入 1)新节点 2&a…

低代码(Low Code):美味膳食还是垃圾食品?如何入门低代码?

文章目录 低代码:美味膳食还是垃圾食品?1. 什么是低代码开发?2. 低代码开发的优势2.1 提高效率2.2 降低门槛 3. 低代码开发的挑战3.1 安全性问题3.2 可扩展性和灵活性问题 4. 低代码开发是美味膳食还是垃圾食品?5. 低代码能否替代…

【Android】查看keystore的公钥和私钥

前言: 查看前准备好.keystore文件,安装并配置openssl、keytool。文件路径中不要有中文。 一、查看keystore的公钥: 1.从keystore中获取MD5证书 keytool -list -v -keystore gamekeyold.keystore 2.导出公钥文件 keytool -export -alias …

天线是什么

天线 电子元器件百科 文章目录 天线前言一、天线是什么二、天线的类别三、天线的应用实例四、天线的作用原理总结前言 不同种类和设计的天线用于不同的应用领域,如广播、电视、无线通信、雷达、卫星通信、导航系统等。常见的天线类型包括柱状天线、片状天线、螺旋天线、饼叶天…

Node.js快速搭建简单的HTTP服务器并发布公网远程访问

文章目录 前言1.安装Node.js环境2.创建node.js服务3. 访问node.js 服务4.内网穿透4.1 安装配置cpolar内网穿透4.2 创建隧道映射本地端口 5.固定公网地址 前言 Node.js 是能够在服务器端运行 JavaScript 的开放源代码、跨平台运行环境。Node.js 由 OpenJS Foundation&#xff0…

西工大计算机学院计算机系统基础实验一(函数编写15~17)

还是那句话,稳住心态,稳住心态,稳住心态。心里别慌,心里别慌,心里别慌。 第15题,howManyBits,返回用二进制补码形式表示x所需的最小二进制位数。比如howManyBits(12) 5,12可以被表…

初学vue3与ts:vue3选项式api获取当前路由地址

vue2的获取方法 this.$route.pathvue3选项式api获取方法 import { useRouter } from vue-router; const router useRouter(); console.log(router) console.log(router.currentRoute.value.path)

测开速成考点

用户登录界面需要做哪些测试? ⑴功能:  正确的用户名,正确的密码,点击提交按钮,验证能否正确登录 是否跳转正确页面。  错误的用户名 或 密码,点击提交,提示相应的错误信息。  记住用户名…

Word文件设置了只读模式,为什么还能编辑?

Word文档设置了只读模式,为什么还可以编辑呢?,不过当我们进行保存的时候会发现,word提示需要重命名并选择新路径才能够保存,是因为什么呢?今天我们学习一下如何解决问题。 这种操作,即使可以编辑…

Python-文件详解

一个计算机包括:CPU、存储器、输入设备、输出设备 存储器分为内存和硬盘 文件路径:一层一层文件目录组成的字符串 文件路径可以视为文件在硬盘中的身份标识,因为每一个文件的1路径唯一 文件之间使用/反斜杠和\正斜杠都一样 内存和硬盘的区别…

AI文本生成工具-免费AI文本生成软件

在当今数字时代,人工智能技术的快速发展不仅改变了我们的生活方式,还在创作领域崭露头角。其中,AI文本生成技术的迅猛发展引起了广泛关注。本文将深入探讨AI文本生成的方法、工具以及一些关键技巧,帮助读者更好地了解并利用这一前…

Run Micro-ROS on almost any stm32

Run Micro-ROS on almost any stm32 - Tech blog (guillaumebeuzeboc.github.io) Run Micro-ROS on almost any stm32 19 Sep 2021 c, cmake, stm32, micro-ros, clion 如果用的不是STM32F4,需要自己去生成micro_ros_stm32cubemx_utils库 Micro-ROS brings the…

UNIX 文件权限设置的相关函数

函数 umask umask 函数为进程设置文件模式创建屏蔽字&#xff0c;并返回之前的值。这个函数没有出错返回&#xff0c;它不会出错. #include <sys/stat.h> mode_t umask(mode_t cmask); // 返回值&#xff1a;为文件模式创建屏蔽字 其中&#xff0c;参数 cmask 是由 文…

qt 5.15.2 主窗体菜单工具栏树控件功能

qt 5.15.2 主窗体菜单工具栏树控件功能 显示主窗体效果&#xff1a; mainwindow.h文件内容&#xff1a; #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow> #include <QFileDialog> #include <QString> #include <QMessageBox>#inc…

m1通过源码编译xgboost4j的jar

1、下载源码 git clone --recursive https://github.com/dmlc/xgboost cd xgboost 编译xgboost的动态链接库dylib&#xff0c;m1源码编译xgboost的动态链接库dylib文件 2、编译XGBoost的jar文件&#xff1a; A、如果没有安装maven可以通过以下命令进行安装&#xff0c;如果安…

【开发技能】-解决visio交叉线(跨线)交叉点弯曲问题

问题 平时工作中使用visio作图时&#xff0c;经常会遇到交叉线在相交时会形成一个弯曲弓形&#xff0c;这十分影响视图效果。可以采用下面的方法消除弓形。 方法 第一步&#xff1a;菜单栏--设计---连接线 第二步&#xff1a;选中这条交叉线---点击显示跨线 最终问题得到解决…

基于ssm学校运动会信息管理系统论文

摘 要 在当今社会上&#xff0c;体育运动越来越普及&#xff0c;参与运动会的人越来越多&#xff0c;但是目前对运动会信息管理还是处于手工记录的时代&#xff0c;这远远满足不了现在用户需求&#xff0c;因此建立一个运动会信息管理系统已经变的非常重要。 本文重点阐述了学…

16个UI设计小规则,但是却能产生巨大影响

我的新书《Android App开发入门与实战》已于2020年8月由人民邮电出版社出版&#xff0c;欢迎购买。点击进入详情 文章目录 1.使用空间对相关元素进行分组2.保持一致3.确保外观相似的元素功能相似4.创建清晰的视觉层次5.删除不必要的样式6.有目的地使用颜色7.确保界面元素的对比…