翼度科技»论坛 云主机 服务器技术 查看内容

docker容器日志时间不一致问题

4

主题

4

帖子

12

积分

新手上路

Rank: 1

积分
12
docker容器日志时间不一致
  1. systemctl start docker 启动docker
复制代码
1.容器与系统日志不一致修改
  1. docker cp /usr/share/zoneinfo/Asia/Shanghai 90b0f5f8df75(容器id):/etc/localtime
复制代码
2.tomcat日志或者插入数据库时间不一致修改

在JAVA_OPTS,webresources后面添加上
  1. -Duser.timezone=GMT+08
复制代码
docker容器时间问题解决

现在很多地方都用Docker 来部署,其好处不多说开干

一、Docker容器与宿主机的时间不对

用于将宿主机的本地时间挂载到容器内。
通过将宿主机的
  1. /etc/localtime
复制代码
目录挂载到容器的相同路径下,容器可以获取宿主机的本地时间并使用它。
这样做的好处是,容器内的应用和服务可以正确地同步宿主机的本地时间,以确保时间的准确性。
这对于一些需要与现实世界时间交互的应用和服务来说非常重要。
  1. docker run -v /etc/localtime:/etc/localtime
复制代码
二、Docker运行的Java应用打印的日志时间不对

宿主机与容器内时间是对得上的,但是输出的日志查了8个钟,试试  -e TZ=Asia/Shanghai,具体来说,
  1. -e
复制代码
参数允许您设置容器的环境变量。
在这种情况下,
  1. TZ
复制代码
是要设置的环境变量的名称,而
  1. Asia/Shanghai
复制代码
是该环境变量的值。
  1. TZ
复制代码
环境变量用于指定容器的时区。
通过将
  1. TZ
复制代码
设置为
  1. Asia/Shanghai
复制代码
,您告诉Docker容器使用上海的时区设置。
当容器运行时,它会自动调整其系统时钟以匹配上海的时区。
这对于确保容器中的时间戳和日志记录与宿主机或其他系统保持一致非常有用。



附上整个的指令
  1. docker run -di -p 7307:7307 -m 4096M --memory-reservation 4096M --name demo  \
  2. --restart=always \
  3. --privileged=true \
  4. -v /var/home/filebrowser/sites/root/jpaas/jars:/home/jpaas/jars  \
  5. -v /var/home/filebrowser/sites/root/jpaas/logs:/logs/jpaas \
  6. -v /etc/localtime:/etc/localtime \
  7. --net=host \
  8. -e TZ=Asia/Shanghai \
  9. frolvlad/alpine-oraclejre8 'sh' '-c' 'java -jar /home/jpaas/jars/demo.jar --server.port=7307 --nacos.address=192.168.201.212:8848  --nacos.namespace=local'
复制代码
总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

来源:https://www.jb51.net/server/321079x44.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具