解决docker中数据库时间与当前时间不吻合

01.问题排查

1.使用mysql数据库查询当前日期的时候发现时间并不吻合

select CURRENT_DATE(),CURRENT_TIME(); 

image-20220313170402993

2.数据库的配置问题

​ 在window11系统上,使用VMware Workstation软件,配置的虚拟机

​ 虚拟机系统为centos7,配置有docker容器。并在docker容器中配置的mysql数据库

(base) [root@192 ~]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                               NAMES
f63b58c00292        mysql               "docker-entrypoint..."   6 weeks ago         Up 14 minutes       0.0.0.0:3306->3306/tcp, 33060/tcp   mysql
62804d3991e8        postgis/postgis     "docker-entrypoint..."   6 weeks ago         Up 16 minutes       0.0.0.0:5432->5432/tcp              postgis

3.查看Centos7系统的当前时间和windows是否一致

(base) [root@192 ~]# date
2022年 03月 13日 星期日 17:08:05 +08

image-20220313170834339

​ 结果是centos7系统的时间与windows吻合

4.最后进入docker 容器中查看容器的时间

(base) [root@192 ~]# docker exec -it mysql /bin/bash
root@f63b58c00292:/# date
Sun Mar 13 09:11:02 UTC 2022

​ 与数据库查询到的当前时间做比对,结果如下:

image-20220313171218538

​ 这里已经定位到需要是docker 容器的时间与Centos虚拟机的时间不匹配

02.修改docker 容器的时间

1.找到centos的时区文件位置:

​ 时区文件目录在:/usr/share/zoneinfo/

​ 应该选择的地区为:Shanghai(虚拟机好像大陆默认只有这个选项)

image-20220313172119588

2.将失去文件拷贝到docker 容器镜像中的对应目录:

​ 下面的mysql为镜像名称,也可以使用对应的容器ID:f63b58c00292

(base) [root@192 Asia]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                               NAMES
f63b58c00292        mysql               "docker-entrypoint..."   6 weeks ago         Up 32 minutes       0.0.0.0:3306->3306/tcp, 33060/tcp   mysql
62804d3991e8        postgis/postgis     "docker-entrypoint..."   6 weeks ago         Up 35 minutes       0.0.0.0:5432->5432/tcp              postgis
(base) [root@192 Asia]# docker cp /usr/share/zoneinfo mysql:/usr/share/

3.宿主机执行以下命令,进入docker容器

​ 同样这个mysql为镜像名,也可以是容器ID

(base) [root@192 ~]# docker exec -it mysql /bin/bash
root@f63b58c00292:/# ls
bin  boot  dev  docker-entrypoint-initdb.d  entrypoint.sh  etc  home  lib  lib64  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var

4.在docker容器中执行设定时区

root@f63b58c00292:/# ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
root@f63b58c00292:/# echo "Asia/Shanghai" > /etc/timezone
root@f63b58c00292:/# date
Sun Mar 13 17:31:14 CST 2022

​ 结果:容器时间已经和windows系统时间对应上了

image-20220313173214546

03.验证

3.1 SQL中的查询到的当前时间

select CURRENT_DATE(),CURRENT_TIME(); 

​ 输出结果:(时间仍然不对)

image-20220313173536513

3.2 重启一下docker中的mysql镜像,再次进行查询

​ 终端上查询效果如下:

(base) [root@192 ~]# date
2022年 03月 13日 星期日 17:38:16 +08
(base) [root@192 ~]# docker restart mysql
mysql
(base) [root@192 ~]# docker exec -it mysql /bin/bash
root@f63b58c00292:/# date
Sun Mar 13 17:38:39 CST 2022
root@f63b58c00292:/# mysql -u root -p
Enter password:
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 8
Server version: 8.0.28 MySQL Community Server - GPL

Copyright (c) 2000, 2022, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> select current_time();
+----------------+
| current_time() |
+----------------+
| 17:39:19       |
+----------------+
1 row in set (0.00 sec)

mysql>

3.3 使用数据库管理工具查看一下当前时间和系统时间是否一致

​ 输出结果如下:时间吻合

image-20220313174123057
​ 总结:

​ 1.虚拟机的时间和windows系统的时间是否一致

​ 2.docker容器的时间和宿主机(这里是虚拟机)的时间是否一致

​ 3.修改玩时间之后,记得要重启一下数据库或者容器

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值