Mysql数据库时区和服务器时区不一致,造成数据库查询结果不一致

问题描述:

  • 测试环境是在服务器用docker进行部署的,构建一个服务中心,需要在上面拉取数据,在本地拉取数据是没有问题的,但是部署到测试环境中会出现数据丢失的问题,缺少将近一百条数据不能拉取,拉取的sql条件是用timestamp的传递值的。

解决问题的过程

  1. 直接使用tomcat启用项目(拉取数据没有问题)
  • 定位是docker容器使用的问题
  1. 更换docker的tomcat镜像,再次启动项目(拉取数据问题存在)
  • 与tomcat镜像无关
  1. 修改代码,将时间戳改成字符串传值(拉取数据问题)
  • 确认与时间戳有关系
  1. 更换docker时区,时间与宿主机一直(拉取数据没有问题)
docker run -v /etc/localtime:/etc/localtime -v /etc/timezone:/etc/timezone 
 /etc/localtime //修改时间
 /etc/timezone //修改时区
  • 最终确认解决方案

总结:

  1. 使用docker镜像一定保证与宿主机时区,时间一致
  2. 但是为啥因为时区和时间问题,会引发mysql查询问题,有待深入研究

后续(解答):

数据库和服务器的时区不一致,docker的美国时区传到宿主机数据库Mysql的时区会进行自动转换,比如docker传过来时间是8点的,转换成上海时区就是16点,是导致数据库查询不一致的根本原因。
所以一定到保证docker和mysql的时区是一致的

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值