偶遇一个线上问题---时间不一致

本地和线上环境时间不一致问题

事情是这样的,有一个业务需要获取当前时间戳,在本地测试的好好的,可是一到线上Linux服务器部署后,

就出现了本地与线上时间不一致的问题

复现一下场景,就不写Service了,直接复现这个场景问题

java 复制代码
public class TestController {
    @GetMapping("/test")
    public Result test(){
        Date date = new Date();
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        return new Result(200,"时间戳为:",simpleDateFormat.format(date).substring(0,19));
    }
}
  • 然后进行本地测试,ok没有问题就是这个时间

  • 再到公网进行测试

  • 发现Linux线上的时间和本地(Macos、Windows)的时间竟然不一致,仔细一看刚好就是差8个钟,总觉得跟某个时区的时间差很像

    查阅资料后发现是Linux读取时间的时候所属的时区跟本地是不一样的,应该是jvm运行的时区设置问题

    在网上看到的解决方法,调整Linux系统时区设置,发现不好使

    ini 复制代码
    vi /etc/sysconfig/clock   #编辑时间配置文件
        ZONE="Asia/Shanghai"
        UTC=false                   #设置为false,硬件时钟不于utc时间一致
        ARC=false
    
    ln -sf /usr/share/zoneinfo/Asia/Shanghai    /etc/localtime    #linux的时区设置为上海时区
    
    ntpdate  cn.pool.ntp.org    #对准时间
    
    /sbin/hwclock --systohc   #设置硬件时间和系统时间一致并校准 

    最后是通过在Java程序启动的时候添加-Duser.timezone=GMT+8参数,解决了时间不一致问题

    以Docker启动Java项目举例,在Dockerfile中添加配置

    ini 复制代码
    # 设置环境变量
    ENV TZ=Asia/Shanghai
    ENV JAVA_OPTS="-Duser.timezone=GMT+8"
相关推荐
SoaringHeart26 分钟前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒2 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰3 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
竹林8183 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
用户8356290780514 小时前
Python 实现 PDF 文件加密与解密方法
后端·python
小满zs4 小时前
Go语言第二章(小无相功)
后端·go
用户8356290780514 小时前
使用 Python 冻结与拆分 Excel 窗格教程
后端·python
karry_k4 小时前
MyBatis批量insert-select踩坑:useGeneratedKeys=true 可能让PostgreSQL返回大量插入结果
java·后端
妙码生花4 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
贰先生4 小时前
Xiuno BBS X版 用户封禁系统
后端