本地(macOS)和服务器时间不同步导致的 Bug排查及解决

问题

今天在开发项目时发现:本地环境运行的项目偶尔会登录不了,提示token无效。

怪了,很久都没动过登录相关的模块了,环境也没动过,怎么会突然登录不了呢。


排查

于是我就去调试了一下登录的模块,发现在token校验里的有效期判断里,偶尔会出现token里的时间比Redis里存的时间大(正常应该是小于或等于的)。

进一步排查后发现我电脑的时间比服务器的时间慢了3秒左右导致的。

为什么是偶现,而不是必现呢?

由于我是本地代码连接线上的Redis服务,中间还有数据库查询,偶尔网络慢的时候刚好把这1秒多抹平了。


解决方法

  1. 进入系统设置-通用-日期与时间:
  1. 进入来源-设定:
  1. 设置时间服务器

阿里时间服务器IP:182.92.12.11

服务器查看时间的命令:

bash 复制代码
date

date命令运行效果:

mac系统同步时间的命令:

bash 复制代码
# 以下命令需要输入密码
sudo sntp -sS 182.92.12.11

sntp命令运行效果:

进一步思考

为什么时间会突然就慢了呢?

我想起近期我的魔法IP不太稳定,切过几次IP源。

是不是新的IP无法访问苹果的时间服务器呢?

于是去验证了一下:

bash 复制代码
# 运行同步时间的命令
# time.apple.com是苹果原装时间服务器
sudo sntp -sS time.apple.com

果然超时了(Exchange failed: Timeout):

OK!破案!

福利

我发现有个网站可以很方便的检查电脑的时间是否和网络时间同步。

地址: tools.manmankan.com/shijian/

对比网站中框红的两个时间,相等的话你本地时间是OK的,不等的话就要调整啦。


关注"大虫小呓"(全网同名),第一时间获得更多技术干货。

这一篇就先水到这啦!下期见!

相关推荐
雪域迷影1 小时前
MacOS中运行Next.js项目注册新用户时MongoDB报错MongoServerError
mongodb·macos·react·next.js
西京刀客4 小时前
macOS 打出来的 tar 包,Linux 常见告警(tar 包里带了 macOS 的扩展属性(xattr))
linux·运维·macos
码农垦荒笔记4 小时前
OpenClaw 实战 #02-1:新手一把过(原Clawdbot )保姆级安装教程-Mac版
人工智能·macos·openclaw
denggun123456 小时前
Material 和 Cupertino
macos·objective-c·cocoa
周杰伦_Jay8 小时前
【Mac 上命令行安装 Claude Code】(Claude 的终端版 AI 编程助手)完整指南
人工智能·macos·claude code
广拓科技8 小时前
微信历史版本含下载地址( Windows PC | 安卓 | MAC )及设置微信不更新
macos·微信
Art&Code8 小时前
M系列Mac保姆级教程:Clawdbot安装+API配置,30分钟解锁AI自动化!
运维·macos·自动化
「已注销」8 小时前
TradingView电脑版下载指南(Windows/Mac)
macos
冰冷的希望8 小时前
【系统】VMware17虚拟机安装黑苹果macOS 15.0详细步骤(保姆级)
macos·操作系统·系统·vmware·虚拟机·黑苹果
yuluo_YX8 小时前
Alias for Linux/Mac
linux·elasticsearch·macos