加入收藏 | 设为首页 | 会员中心 | 我要投稿 拼字网 - 核心网 (https://www.hexinwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 服务器 > 搭建环境 > Linux > 正文

Linux 时间同步 ntpd&chrony 内网

发布时间:2022-12-09 14:04:03 所属栏目:Linux 来源:网络
导读: Linux 时间同步 ntpd&chrony
在任何服务器集群中,为了更好的协同工作,除了一些互信机制外,需要的就是时间同步功能,如果时间不同步,就好比让在中国的同事与美国的同事进行沟通,会造成

Linux 时间同步 ntpd&chrony

在任何服务器集群中,为了更好的协同工作,除了一些互信机制外,需要的就是时间同步功能,如果时间不同步,就好比让在中国的同事与美国的同事进行沟通,会造成各种奇奇怪怪的时间相关的问题。而且很多资源访问都是有时效性的,如果时间不同步可能永远无法访问,对此我们需要进行时间同步的功能。

Linux 时间系统

在 windows 系统中,我们设置时间的时候一般都是通过右下角进入时间的设置界面进行设置,在设置过程中都是页面化,而且在我们关机、重启后都没有问题。系统时间会自动保存在 BIOS 时钟中,这样电脑启动也会从 BIOS 中获取硬件的时间,以保证时间的不间断。

但在 linux 中,系统时间和硬件时间并不会自动同步,他们是互不干扰的。硬件使用 BIOS 电池维持;系统时间使用 CPU Tick 维持,启动时获取 BIOS 时间。

Linux 系统时间设置

在 Linux 中我们可以通过 date 命令进行设置:

# 查看当前时间
date
# 更改系统时间
date -s "19970118 20:00:00"
# 再次查看系统时间
date

服务器集群 linux_集群linux_linux服务器集群

Linux 硬件时间设置

硬件时间的设置可以使用 clock 或者 hwclock 命名,推荐使用第一个。

# 打印当前硬件时间
clock
# 设置当前硬件时间
clock --set --date "19970118 20:00:00"
# 再次打印硬件时间
clock

在这里插入图片描述

这时候我们可以查看这个文件 /etc/adjtime,如果我们更改了硬件时间,那么这个文件会记录两次时间的调整差异,后续如果再次使用 --set 或 --systohc 命令,会自动计算出差异平均值,进行硬件时钟的调整:

Linux 系统和硬件时间同步

现在我们将两个时间都定位到了 1997 年,现在我们需要进行一些同步,将时间矫正回来。(请确保有外网)

安装 ntpdate 服务

ntpdate 会在本文后面进行对应讲解,现在我们单台进行 ntpdate 服务器安装。

yum install ntpdate ntp

同步 ntp 时间

ntpdate -u cn.pool.ntp.org  
# 也可以使用
# 上海的 NTP 服务器: ntp.api.bz
# 中国ntp服务器:cn.pool.ntp.org
# 上海交通大学网络中心NTP服务器:ntp.sjtu.edu.cn
# 阿里: ntp1.aliyun.com

查看系统时间

date
clock

在这里插入图片描述

可以看到我们的系统时间已经同步完成,但是硬件时间还停留在 1997 年。那么我们可以将系统时间同步到硬件时间:

# 将系统时间赋予硬件时间
clock -w
clock

集群时间同步

刚刚我们了解了 Linux 的时间系统,也完成了单服务器的同步到国家时间的流程,那如果我们需要自己搭建集群,也需要保证集群的时间同步,但没有外网环境。那么我们需要自己搭建时间基准,并通过这个基准,进行整个集群的时间同步。

现在一般有两种同步方法: ntpdate 和 chrony。更推荐 chrony,下面会讲解两个的使用方法。

ntpd 服务

NTP 其实就是 Network Time Protocol 网络时间协议,可以使计算机时间同步化的一种协议集群linux,可以使计算机对服务器或者时钟源进行同步。

前面我们已经安装过 ntpdate 了,现在快速回忆单台同步外网 ntp 服务器:

yum install ntpdate ntp
ntpdate -u ntp1.aliyun.com

集群时间主服务器

可以看到,如 ntp1.aliyun.com 其实就是一台外网可以访问的时间服务器,所以在我们需要搭建的集群中,也需要有这样一台时间服务器。这里我们选择 maggot111128.huangyichun.com 作为主服务器,其他在这台服务器上进行时间同步。

在这里插入图片描述

参考官网:

开启 ntpd 服务

systemctl status ntpd # 查看服务状态
systemctl start  ntpd # 启动服务
systemctl enable ntpd # 设置开机启动
systemctl status ntpd # 再次查看

在这里插入图片描述

在安装了 ntp 后,相关的配置在 /etc/ntp.conf 中。我们需要进行一些配置 vim /etc/ntp.conf:

提供服务器网段扩大

# 在 acccess 中添加
# Permit all access over the loopback interface.  This could
# be tightened as well, but to do so would effect some of
# the administrative functions.
restrict 127.0.0.1
restrict ::1
restrict 192.168.0.0 # 可以对 192.168.0.0网段提供服务
# or
# restrict 192.168.111.0 mask 255.255.255.0 nomodify notrap

该节点更改为只与自己同步

# 注释掉server 开头的行,取消同步其他服务器
# Use public servers from the pool.ntp.org project.
# Please consider joining the pool (http://www.pool.ntp.org/join.html).
#server 0.centos.pool.ntp.org iburst
#server 1.centos.pool.ntp.org iburst
#server 2.centos.pool.ntp.org iburst
#server 3.centos.pool.ntp.org iburst
server 127.127.1.0 # 添加自己为时间同步服务器
127.127.1.0 stratum 8 # 并设置自己的层级(最多16层)

重启 ntpd 服务

systemctl restart ntpd

集群客户端服务器

集群中的其他服务器要与这台服务器进行时间同步,也需要 ntp 服务,在安装完后进行 /etc/ntp.conf 的配置:

yum install ntp ntpd
vim /etc/ntp.conf
# Use public servers from the pool.ntp.org project.
# Please consider joining the pool (http://www.pool.ntp.org/join.html).
#server 0.centos.pool.ntp.org iburst
#server 1.centos.pool.ntp.org iburst
#server 2.centos.pool.ntp.org iburst
#server 3.centos.pool.ntp.org iburst
server maggot111128.huangyichun.com  # 添加需要同步的服务器
server maggot111128 # 添加需要同步的服务器

然后启动 ntpd 服务:

systemctl start  ntpd
systemctl enable ntpd
systemctl status ntpd

使用 ntpstat 查看同步状态:

在这里插入图片描述

当前处于未同步状态,如果需要手动同步:

ntpdate -d  maggot111128

如果出现类似于 no server suitable for synchronization found,请查看主服务器的防火墙设置:

在这里插入图片描述

防火墙设置参考:

firewall-cmd --stat # 查看防火墙是否开启
firewall-cmd --zone=public --list-ports # 在开启情况下,打开了哪些通道
firewall-cmd --zone=public --add-port=123/tcp --permanent # 开启123/tcp通道
# or
# 直接关闭防火墙
systemctl stop firewalld

注意,仅仅这样并不会让硬件时间进行同步,需要更改 /etc/sysconfig/ntpd 文件:

SYNC_HWCLOCK=yes

下图为更改前:

在这里插入图片描述

更改后(记得重启 ntpd):

在这里插入图片描述

chrony 服务

Chrony 是开源的时间同步服务,是 centos7 的默认时间同步工具。能够与时间服务器进行时间同步,并始终让时间保持同步,比 NTP 更快、配置更简单、依赖更简单。

注意进行 chrony 安装之前,我们需要停止 ntpd 相关服务。

# 所有节点均停止 ntpd 服务
systemctl status ntpd
systemctl stop ntpd
systemctl disable ntpd
systemctl status ntpd
# 查看 ntpd 默认端口123 是否被占用
netstat -tunlpa  |grep 123

在这里插入图片描述

chrony 时间源

跟 ntpd 服务器一样,我们需要搭建 chrony 的事件源服务器,首先安装 chrony 服务(如果是 centos 7 应该是默认安装)

yum install chrony

使用 /etc/chrony.conf 进行 chrony 相关配置

vim /etc/chrony.conf
# 与 ntpd 一致,将自己设置为 server 节点
# Use public servers from the pool.ntp.org project.
# Please consider joining the pool (http://www.pool.ntp.org/join.html).
#server 0.centos.pool.ntp.org iburst
#server 1.centos.pool.ntp.org iburst
#server 2.centos.pool.ntp.org iburst
#server 3.centos.pool.ntp.org iburst
server 127.0.0.1 iburst
# 如果有外网,建议添加
server ntp.aliyun.com iburst 
# 如果是私网必须添加
local stratum 10
# 打开允许同步的网段
# Allow NTP client access from local network.
#allow 192.168.0.0/16
allow 192.168.0.0/16

然后重启 chrony 服务,并查看服务状态

systemctl restart chronyd.service
systemctl enable  chronyd.service  # 开机启动
# 查看服务状态
systemctl status chronyd -l
chronyc sources -v 
# 查看端口同步
netstat -tunlpa |grep 123
# 检查是否同步
<strong>chronyc tracking</strong>
# 需要注意 最后一行 Leap Status

chrony 客户端

安装 chrony

yum install chrony

更改配置文件

vim /etc/chrony.conf
# Use public servers from the pool.ntp.org project.
# Please consider joining the pool (http://www.pool.ntp.org/join.html).
#server 0.centos.pool.ntp.org iburst
#server 1.centos.pool.ntp.org iburst
#server 2.centos.pool.ntp.org iburst
#server 3.centos.pool.ntp.org iburst
server maggot111128.huangyichun.com

重启 chronyd 服务

systemctl restart chronyd.service

使用 chronyc sources 命令进行同步查看,如果出现 ^* 则为获取时间成功,正在同步中,错位时间看 Last:

在这里插入图片描述

chronyc 命令

使我们操控 chrony 的命令方式,主要有:

参数参数说明

sources

查看所有服务器同步情况

accheck

检查NTP访问是否对特定主机可用

activity

该命令会显示有多少NTP源在线/离线

add server

手动添加一台新的NTP服务器。

clients

在客户端报告已访问到服务器

delete

手动移除NTP服务器或对等服务器

settime

手动设置守护进程时间

tracking

显示系统时间信息

集群搭建注意事项

一般我们进行搭建的时候可能都是只选择了一台节点作为时间服务器,但是其实在超大型集群搭建的时候,我们应该按照网段进行区别,采用多时间服务器的方式进行搭建。不要像一棵树,只有一个根。

(编辑:拼字网 - 核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!