keycloak~时间不正确的问题
首先我们应该知道,写到数据库里的时间,主要和你的mysql时区system_time_zone
有关,而把mysql里的数据取出来,以json形式响应到浏览器上,这个时间会经过反序列化的过程,这时时间和注解@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
有关。
和我们相关的几个时区
- UTC: Coordinated Universal Time, 国际协调时间,也称世界标准时间。
- GMT:Greenwich Mean Time, 格林尼治时间
- CST:中国标准时间(China Standard Time),为GMT+8
- BST:英国夏令时间,为GMT+1
- CST:美国中部时间(Central Standard Time),为GMT-6,正常比北京慢14小时,夏令时慢13小时
- 东八区:GMT+8
数据库时区
1、首先查看MySQL当前的时间
select curtime();
show variables like "%time_zone%";
time_zone说明mysql使用system的时区,system_time_zone说明system使用CST时区
2、进行修改
set global time_zone = '+8:00'; #修改mysql全局时区为北京时间,也就是我们所在的东8区
set time_zone = '+8:00'; #修改当前会话时区
flush privileges;
直接在数据库连接串上添加时区
serverTimezone=GMT%2B8 #表示东八区
为代码添加对象的时区注解
@Column(name = "EXPIRE_DATE")
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
private Date expireDate;
修改k8s中pod的时区
...
containers:
- name: xxx
env:
- name: TZ
value: Asia/Shanghai
...
volumeMounts:
- name: timezone
mountPath: /etc/localtime
volumes:
- name: timezone
hostPath:
path: /usr/share/zoneinfo/Asia/Shanghai
总结
事实上,数据库里的时间与显示出现的时间不一致,与pod的时间没关系,主要还是看你的数据库时区与@JsonFormat注解的时区。
- 如果@JsonFormat如果是GMT+8,而连接串里是GMT+0,会出现下面截图
- 如果@JsonFormat如果是GMT+8,连接串里也是GMT+8,会出现我们想要的截图
- 最后,如果@JsonFormat如果是GMT+8,连接串里也是CST(可能被认为是美国中部时间,GMT-6),那么它将会比北京时间慢8+6小时
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示
2019-04-12 设计一下类似SpringIoC的注入工具~Lind.DI
2017-04-12 docker~docker-machine的介绍
2016-04-12 Redis学习笔记~分布式的Pub/Sub模式
2016-04-12 Linux~常用的命令
2016-04-12 实时监控Cat之旅~配置Cat集群需要注意的问题
2013-04-12 知方可补不足~CSS中margin,padding,border-style有几种书写规范
2013-04-12 JQ也要面向对象~在JQ中扩展静态方法和实例方法