当前位置: 首页 > news >正文

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

问题

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

接口报错

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


排查

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

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

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

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


解决方法

  1. 进入系统设置-通用-日期与时间:

系统设置-通用-日期与时间

  1. 进入来源-设定:

来源-设定

  1. 设置时间服务器

原设置

阿里时间服务器IP:182.92.12.11

设置为阿里时间服务器IP

服务器查看时间的命令:
date

date命令运行效果:

date命令运行效果

mac系统同步时间的命令:
# 以下命令需要输入密码
sudo sntp -sS 182.92.12.11

sntp命令运行效果:

sntp

进一步思考

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

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

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

于是去验证了一下:

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

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

运行同步时间的命令-效果

OK!破案!

福利

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

地址:
https://tools.manmankan.com/shijian/

网站截图

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


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

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

http://www.xdnf.cn/news/1287001.html

相关文章:

  • 从裸机到云原生:Linux 操作系统实战进阶的“四维跃迁”
  • 【Linux】程序地址空间
  • CTO如何通过录音转写和音频降噪,提升企业远程协作效率?
  • 定制客车系统线上购票系统功能设计
  • springboot+JPA
  • 机械臂的智能升维:当传统机械臂遇见Deepoc具身智能大模型从自动化工具到具身智能体的范式革命
  • 【KO】android 音视频
  • Elasticsearch JavaScript 客户端「基础配置」全指南(Node/TS)
  • AWT与Swing深度对比:架构差异、迁移实战与性能优化
  • Git 常用命令速查表
  • java面试题储备4: 谈谈对es的理解
  • 【Go】Gin 超时中间件的坑:fatal error: concurrent map writes
  • iOS 编译 cpp 代码生成 .a 库备忘
  • 医美产业科技成果展陈中心:连接微观肌肤世界与前沿科技的桥梁
  • 微算法科技(NASDAQ:MLGO)开发经典增强量子优化算法(CBQOA):开创组合优化新时代
  • 非凸科技受邀参加Community Over Code Asia 2025 Rust分论坛
  • 云计算分类与主流产品
  • 【论文阅读】一种基于经典机器学习的肌电下肢意图检测方法,用于人机交互系统
  • 【Node.js从 0 到 1:入门实战与项目驱动】2.1 安装 Node.js 与 npm(Windows/macOS/Linux 系统的安装步骤)
  • 网络基础设施保护
  • python题目练习 是否所有1都至少相隔k个元素 简单类型
  • 开博尔DA5耳放小尾巴体验评测:实体按键给到位,便携HiFi上手挺好用的
  • 25C机场航班调度程序(JS 100)
  • Ansible 基础到实操笔记
  • MySQL数据库操作全指南:数据库命令、表命令与数据CRUD操作
  • 飞算 JavaAI -智慧城市项目实践:从交通协同到应急响应的全链路技术革新
  • vue excel转json功能 xlsx
  • 正则表达式解析(二)
  • Python 标准库模块shutil
  • 升级 Docker,避免执行 docker compose 时报错