一键设置 NTP & 时区的脚本(亲测,适用于部署 K8S 的前置环境)

文章目录

一、时区和时间同步的配置命令

整理用于做时区和时间同步的配置几条命令分别如下:

1️⃣ 编辑 chrony 配置

bash 复制代码
vim /etc/chrony.conf

一般是修改 NTP 服务器,比如换成阿里云、腾讯云等国内源,例如:

bash 复制代码
server ntp.aliyun.com iburst
server ntp1.aliyun.com iburst

2️⃣ 设置系统时区为上海时间

bash 复制代码
ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
#-sf:强制创建软链接,替换原来的 /etc/localtime,让系统使用上海时区。

3️⃣ 写入时区信息到 /etc/timezone

bash 复制代码
echo 'Asia/Shanghai' > /etc/timezone

有些程序会读取 /etc/timezone 来判断时区,这步是为了兼容。

4️⃣ 重启时间同步服务

bash 复制代码
systemctl restart chronyd
systemctl enable chronyd

5️⃣ 检查同步状态

bash 复制代码
chronyc sources -v

可以看到当前 NTP 同步源和同步状态。

写了一个一键设置 NTP & 时区的脚本,适用于你这种部署 Rancher + K8S 的环境,保证所有节点时间同步一致,避免 TLS 证书和集群时间漂移问题。

二、完整脚本ntp_timezone_setup.sh

bash 复制代码
# 一键配置 NTP 和时区
# 适用系统:CentOS / RHEL / Rocky / Alma / Amazon Linux 2

set -e

echo "=== 1. 设置时区为 Asia/Shanghai ==="
ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
echo "Asia/Shanghai" > /etc/timezone

echo "=== 2. 安装 chrony(如果未安装) ==="
yum install -y chrony

echo "=== 3. 备份原有 chrony 配置 ==="
cp /etc/chrony.conf /etc/chrony.conf.bak.$(date +%F_%T)

echo "=== 4. 配置阿里云 NTP 源 ==="
cat > /etc/chrony.conf <<EOF
server ntp.aliyun.com iburst
server ntp1.aliyun.com iburst
server ntp2.aliyun.com iburst
server ntp3.aliyun.com iburst
server ntp4.aliyun.com iburst
server ntp5.aliyun.com iburst
driftfile /var/lib/chrony/drift
makestep 1.0 3
rtcsync
EOF

echo "=== 5. 启动并设置开机自启 chronyd ==="
systemctl enable --now chronyd

echo "=== 6. 等待时间同步中... ==="
sleep 3
chronyc sources -v

echo "=== 7. 检查系统时间 ==="
date

echo "✅ 配置完成:NTP 同步已启用,时区已设置为 Asia/Shanghai"

三、使用方法

3.1、创建脚本

bash 复制代码
vim ntp_timezone_setup.sh

粘贴上面的内容并保存。

3.2、赋予执行权限

bash 复制代码
chmod +x ntp_timezone_setup.sh

3.3、运行脚本

bash 复制代码
./ntp_timezone_setup.sh

3.4、验证

bash 复制代码
timedatectl
chronyc tracking


建议把这个脚本在 所有 Rancher/K8S 节点 都执行一次,这样控制平面和 worker 节点的时间会绝对一致,不会再出现你前面提到的tls: failed to verify certificate: x509: certificate signed by unknown authority 这种因时间差导致的错误。


"人的一生会经历很多痛苦,但回头想想,都是传奇"。


相关推荐
Joren的学习记录21 分钟前
【Linux运维大神系列】Kubernetes详解3(kubeadm部署k8s1.23高可用集群)
linux·运维·kubernetes
Hellc00723 分钟前
Docker网络冲突排查与解决方案:完整指南
网络·docker·容器
hanyi_qwe38 分钟前
发布策略 【K8S (三)】
docker·容器·kubernetes
眠りたいです43 分钟前
Docker核心技术和实现原理第二部分:docker镜像与网络原理
运维·网络·docker·容器
Mr. Cao code2 小时前
Docker数据管理:持久化存储最佳实践
java·docker·容器
Cyber4K4 小时前
【Kubernetes专项】DockerFile、数据持计划、网络模式及资源配额
运维·网络·云原生·容器·kubernetes
Joren的学习记录5 小时前
【Linux运维疑难杂症】k8s集群创建calico网络失败
linux·运维·kubernetes
鲨莎分不晴5 小时前
Docker 网络深度解析:打破容器的“孤岛效应”
网络·docker·容器
Zsr10235 小时前
K8s核心组件Pod:基础篇
云原生·容器·kubernetes
nix.gnehc5 小时前
Serverless
云原生·serverless