docker获取数据库时间相差8小时_docker之容器日志输出与系统时间相差8小时解决办法...

本文介绍了在使用Docker部署容器时,遇到日志时间与系统时间相差8小时的问题,以及如何通过挂载系统时区文件解决这个问题。首先检查环境,创建并查看容器日志,发现时间不一致。接着,尝试通过-v参数链接系统时区文件,但发现日志时间依然未正确同步。最后,通过修改MySQL配置文件中的`log_timestamps`设置为`SYSTEM`,确保日志记录使用系统时区,从而成功解决时间差异问题。
摘要由CSDN通过智能技术生成

参考:https://blog.csdn.net/eumenides_/article/details/94719944

https://muguang.me/it/2658.html

使用docker部署容器时,输出日志时间会比系统正常时间少8小时

1,环境查看

2,创建容器查看日志

启动一个容器

docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 --name mysql3306 mysql:5.7

查看日志

docker logs mysql3306

可以看到日志比系统时候少8小时

登录容器查看时区和时间(于日志时间一致)

root@217fd4ef2dc7:/# date

Fri Aug 16 06:55:12 UTC 2019

root@217fd4ef2dc7:/# date -R

Fri, 16 Aug 2019 06:55:15 +0000

删除容器

docker kill mysql3306

docker rm mysql3306

新建一个容器使用链接让容器使用系统时区

docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /etc/timezone:/etc/timezone:ro -v /etc/localtime:/etc/localtime:ro --name mysql3306 mysql:5.7

-v链接系统时区

可以在宿主机查看这两个时区文件

root@test-docker01:/nas/scripts# ll /etc/localtime

lrwxrwxrwx 1 root root 33 7月 7 06:05 /etc/localtime -> /usr/share/zoneinfo/Asia/Shanghai

root@test-docker01:/nas/scripts# cat /etc/timezone

Asia/Shanghai

查看日志,时间还是相差8小时

docker logs mysql3306

登录容器查看

./docker_in.sh mysql3306

日期和时区设置是正常的

root@f6a3ea6e7b42:/# date

Fri Aug 16 15:01:59 CST 2019

root@f6a3ea6e7b42:/# date -R

Fri, 16 Aug 2019 15:02:01 +0800

MySQL使用记录日志还有一个设置需要修改

登录MySQL查看,日志记录使用UTC时区,需要修改成系统时区

MySQL [(none)]> show variables like "log_timestamps";

+----------------+-------+

| Variable_name | Value |

+----------------+-------+

| log_timestamps | UTC |

+----------------+-------+

1 row in set (0.01 sec)

临时修改

set global log_timestamps="SYSTEM";

再次查看

MySQL [(none)]> show variables like "log_timestamps";

+----------------+--------+

| Variable_name | Value |

+----------------+--------+

| log_timestamps | SYSTEM |

+----------------+--------+

1 row in set (0.00 sec)

使用错误的密码登录一次产生日志再次查看日志时间对了

设置永久生效,修改MySQL配置文件my.cnf

[mysqld]

log_timestamps=SYSTEM

如果是使用docker-compose启动则需要修改配置文件添加以下内容

volumes:

- ./mysql/conf:/etc/mysql/conf.d

- ./mysql/data:/var/lib/mysql

- /etc/localtime:/etc/localtime:ro

- /etc/timezone:/etc/timezone:ro

同时修改mysql配置文件

PS:如果docker-compose已经启动则添加配置重启无效需要删除容器再重新up才能生效

docker-compose down

docker-compose up -d

解决weblogic与系统时间相差8小时的问题

解决weblogic与系统时间相差8小时的问题 在一般情况下weblogic与系统时间是很少会出现时间差的问题,但有可能在某一特定的情况下就会出现,如使用weblogic8版本时可能会出现时差问题: ...

Manjaro 与 Windows 双系统时间相差8小时

Manjaro 与 Windows 双系统时间相差8小时 产生原因: Windows 将本地硬件时间作为设定时区(如 UTC+8)的区时,而 Linux 默认将其作为 UTC 时间. 解决方式: 让 ...

win7和ubuntu双系统,win7时间晚8小时解决办法。

装了Win7和Ubuntu双系统后发现,使用Ubuntu后再登陆win7时系统显示时间不准确,比实际时间晚了8小时. 搜索后发现原来Linux和Windows的系统时间管理是不同的.Linux是以主板 ...

CentOS系统时间与现在时间相差8小时解决方法

很多网友在安装完CentOS系统后发现时间与现在时间相差8小时,这是由于我们在安装系统的时选择的时区是上海,而CentOS默认bios时间是utc时间,所以时间相差了8小时.这个时候的bios的时间和 ...

centos7系统日志时间与系统时间相差8小时

场景:当我们修改完系统时间的时区后,我们去查看我们的系统日志的时间发现时区还是在之前的系统时间时区. [root@vp-n ~]# ls -l /etc/localtime lrwxrwxrwx 1 ...

Docker进入容器后使用ifconfig等命令“command not found”解决办法

当进入一个容器后,使用ifconfig.ip addr等命令时,出现如下“command not found”:       解决办法:   yum update yum -y install n ...

Java获取时间与系统时间相差8小时终极解决方案

一.在取日期以前设置一下时区 TimeZone tz = TimeZone.getTimeZone(“ETC/GMT-8″);TimeZone.setDefault(tz); 此种方法适用于单次快速获 ...

苹果与Windows双系统时间不同步的解决办法

步骤:打开C盘>Windows>System32,找到cmd.exe,右键以管理员的身份运行. Reg add HKLM\SYSTEM\CurrentControlSet\Control\ ...

【转】PHP date("Y-m-d H:i:s");获取当前时间 差8小时解决办法

原因:                                                                                              网络资 ...

随机推荐

OpenCASCADE Coordinate Transforms

OpenCASCADE Coordinate Transforms eryar@163.com Abstract. The purpose of the OpenGL graphics process ...

Android中过场动画

overridePendingTransition(R.anim.slide_in_right,R.anim.slide_out_left); 第一参数为进入的动画 第二参数为退出的动画 进入的动画 ...

如何把其他用户创建的表,导入到自己数据库是,所有者owner改变为自己创建的用户

1. 导出用户 expdp user1/pass1 directory=dumpdir dumpfile=user1.dmp2. 导入用户 impdp user2/pass2 directory=d ...

tornado框架之路二

二.路由系统 路由系统其实就是 url 和 类 的对应关系,这里不同于其他框架,其他很多框架均是 url 对应 函数,Tornado中每个url对应的是一个类. #!/usr/bin/env pyth ...

tomcat https 配置

以前基本上笔者对于安全性考虑的并不多,最近因为saas平台要开始逐渐推广,所以需要开始逐渐加强xss/crsf/https等措施以避免潜在的安全性风险.本文简单的记录下tomcat下https的配置. ...

C#中禁止程序多开

原文:C#中禁止程序多开 方法一.使用Mutex bool createdNew; //返回是否赋予了使用线程的互斥体初始所属权            System.Threading.Mutex i ...

Glog使用记录

1.Flag_xxx FLAGS_logtostderr = false; //是否将所有日志输出到stderr,而非文件 FLAGS_alsologtostderr = false; //日志记录到 ...

记录flask使用模板时出现的“Internal Server Error”错误

在看时照着书上的代码抄了一遍,然后运行时发现一直出现以下的错误 书上的源代码如下 watchlist.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值