背景
最近在做一个测试,测试时从serviceA向serviceB发送请求,在发送请求的时候有鉴权,鉴权的参数包含时间戳。在调用过程中发现serviceA的时间和serviceB的时间相差了16个小时,立即想到了应该是时钟不同步的问题。因此需要调整serviceA所在的服务器的时钟,就有了这篇文章。
时钟同步
首先在ubuntu系统中,时间校准通常是通过NTP(Network Time Protocol)
来进行的。一般在Ubuntu安装的时候会默认安装systemd-timesyncd
服务来对时间进行管理的。
- 首先检查
systemd-timesyncd
服务状态。
shell
sudo systemctl status systemd-timesyncd.service
服务状态正常。
- 执行
date
命令查看系统时间,发现时间仍然不对。怀疑是不是系统的时区设置的不对。设置系统市区为东八区。
shell
timedatectl list-timezones|grep Shan
列出系统支持的时区。结果中包含Shanghai
shell
timedatectl set-timezone Asia/Shangha
查看执行结果:
shell
timedatactl status
- 再次执行
date
命令发现时间仍没有发生变化。考虑手动指定时间,但是手动设置时间存在时间被NTP覆盖的问题,不利于后续时间的维护。放弃该方法。 - 再次查看
systemd-timesyncd
状态。
此时的status
状态为'idle',idle
状态表示systemd-timesyncd
服务正在等待进行时间同步,或者在尝试同步后进入了空闲状态。这个状态不一定表示有问题,因此需要继续检查systemd-timesyncd
的日志。执行如下命令: shell journalctl -u systemd-timesyncd
结果如下所示:
可以看到ntp
服务一直在同步时间,但是无法得到响应,猜测应该是网络的问题。至于修复方式也很简单,修改ntp服务配置,使其能够访问国内的ntp服务器。
- 打开
/etc/systemd/timesyncd.conf
文件,添加以下内容
ini
[Time]
NTP=ntp.aliyun.com
-
重启
systemd-timesyncd
服务。sudo systemctl restart systemd-timesyncd
-
再次检查时间,结果符合预期。
小结
NTP
虽然是一个很小的知识点,但是问题的排查过程涉及到Ubuntu后台进程的管理,目前Centos和Ubuntu主流的linux发行版都采用systemd座位后台进行管理工具,因此掌握systemd对于Linux的运维和管理非常重要,后面单开一篇文章来介绍systemd。