问题描述:

  • 测试环境是在服务器用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的时区是一致的

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐