关于Linux Docker springboot jar 日志时间不正确 问题解决

使用Springboot项目的jar,制作了一个Docker镜像,启动该镜像后发现容器和容器中的Springboot 项目的日志时间不正确。

解决

查看容器时间命令为:

docker exec 容器id date

1. 容器与宿主机同步时间

在启动镜像时候把操作系统的时间通过"只读"的方式挂载到容器中

添加命令行配置

java 复制代码
-v /etc/localtime:/etc/localtime:ro

比如:

2. Spring boot Jar 启动时增加时区参数

在制作镜像时候,运行jar时指定上时区参数,以便Springboot项目中的日志中能够正确读取到指定时区的时间。中国采用东八区的时区,所以是GMT+8

-Duser.timezone=GMT+8

如:

java 复制代码
java -jar -Duser.timezone=GMT+8 your_application.jar

对应的Dockerfile应该为

java 复制代码
ENTRYPOINT ["java", "-jar", "-Duser.timezone=GMT+8", "/app.jar"]

或是

java 复制代码
CMD java -Duser.timezone=GMT+8 -jar lamp-likang-server.jar

我的是

最后删除镜像,重新打包镜像 启动容器 查看日志就发现同步了

相关推荐
小雪_Snow几秒前
Ubuntu 安装教程
linux·ubuntu
q***42828 分钟前
Redis 设置密码(配置文件、docker容器、命令行3种场景)
数据库·redis·docker
IT逆夜28 分钟前
linux系统安全及应用
linux·运维
i02081 小时前
SpringBoot 项目配置
java·spring boot·后端
计算机毕业设计小途1 小时前
计算机毕业设计推荐:基于springboot的快递物流仓库管理系统【Java+spring boot+MySQL、Java项目、Java毕设、Java项目定制定
java·spring boot·mysql
苹果醋31 小时前
VueX(Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式)
java·运维·spring boot·mysql·nginx
Forest_HAHA1 小时前
<10>_Linux网络基础(上)
linux·服务器
i***58672 小时前
springboot中配置logback-spring.xml
spring boot·spring·logback
c++逐梦人2 小时前
Linux下的编辑器vim的介绍
linux·编辑器·vim
J***Q2922 小时前
Docker镜像多平台构建
运维·docker·容器